你是如何使用Machine.config的,或者是你?

时间:2008-09-18 16:15:32

标签: .net asp.net deployment configuration

对于ASP.Net应用程序部署,您在machine.config中存储了哪些类型的信息(如果有)?

如果您没有使用它,您如何管理可能针对每个环境更改的特定于环境的配置设置?

我正在寻找一些“最佳实践”以及每种方法的好处/陷阱。我们即将在两个月内将一个全新的应用程序部署到生产中,我在这些类型的决策中有一定的自由度。我想确保我以尽可能最好的方式接近事物,并试图避免以后在脚下射击自己。

仅供参考我们目前正在使用它(machine.config)来获取数据库连接信息并存储可能在数据库中的配置表中更改的所有其他变量。

4 个答案:

答案 0 :(得分:8)

我们正在考虑使用machine.config为环境添加一个密钥,然后在web.config中有一个部分,对于所有环境来说都是完全相同的。这样我们就可以进行“真正的”XCopy部署。

E.g。在每台计算机(本地开发工作站,阶段服务器,构建服务器,生产服务器)的machine.config中,我们将添加以下内容:

<appSettings>
    <add key="Environment" value="Staging"/>
</appSettings>

然后,任何特定于环境的配置元素都会附加环境,如下所示:

<connectionStrings>
    <add name="Customers.Staging" provider="..." connectionString="..."/>
</connectionStrings>
<appSettings>
    <add key="NTDomain.Staging" value="test.mydomain.com"/>
</appSettings>

我们没有解决方案的一个问题是如何在web.config中启用说跟踪以调试环境而不是实时环境。

另一个问题是live connectionstring incl。用户名和密码现在位于源代码管理系统中。然而,这对我们来说不是问题。

答案 1 :(得分:8)

如果您对服务器进行负载平衡,则绝对必须确保所有服务器上的计算机密钥相同。 Viewstate应该与服务器无关,但事实并非如此,因此如果服务器上的机器密钥不同,则会出现viewstate损坏错误。

<machineKey validationKey='A130E240DF1C49E2764EF8A86CEDCBB11274E5298A130CA08B90EED016C0
14CEAE1D86344C29E67E99DF83347E43820050A2B9C9FC89E0574BF3394B6D0401A9'
decryptionKey='2CC37FFA8D14925B9CBCC0E3B1506F35066FEF33FEB4ADC8' validation='SHA1'/>

来自:http://www.c-sharpcorner.com/UploadFile/gopenath/Page107182007032219AM/Page1.aspx

PS确定你可以启用ViewStateMAC =“false”,但不要。

答案 2 :(得分:5)

我们在生产服务器上使用machine.config来设置/删除对生产很重要的特定配置,我们永远不会忘记设置它们。

这是最重要的两个:

<system.web>
    <deployment retail="true" />
    <healthMonitoring enabled="true" />
</system.web> 

答案 3 :(得分:2)

我不仅将machine.config用于ASP.NET,还用于整体配置。我在C#中实现了一个哈希算法(Tiger),并希望它可以通过机器请求获得。因此,在GAC中注册了我的程序集并将以下内容添加到machine.config:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <mscorlib>
        <cryptographySettings>
            <cryptoNameMapping>
                <cryptoClasses>
                    <cryptoClass Tiger192="Jcs.Tiger.Tiger192, Jcs.Tiger, Culture=neutral, PublicKeyToken=66c61a8173417e64, Version=1.0.0.4"/>
                    <cryptoClass Tiger160="Jcs.Tiger.Tiger160, Jcs.Tiger, Culture=neutral, PublicKeyToken=66c61a8173417e64, Version=1.0.0.4"/>
                    <cryptoClass Tiger128="Jcs.Tiger.Tiger128, Jcs.Tiger, Culture=neutral, PublicKeyToken=66c61a8173417e64, Version=1.0.0.4"/>
                </cryptoClasses>
                <nameEntry name="Tiger" class="Tiger192"/>
                <nameEntry name="TigerFull" class="Tiger192"/>
                <nameEntry name="Tiger192" class="Tiger192"/>
                <nameEntry name="Tiger160" class="Tiger160"/>
                <nameEntry name="Tiger128" class="Tiger128"/>
                <nameEntry name="System.Security.Cryptography.HashAlgorithm" class="Tiger192"/>
            </cryptoNameMapping>
            <oidMap>
                <oidEntry OID="1.3.6.1.4.1.11591.12.2" name="Jcs.Tiger.Tiger192"/>
            </oidMap>
        </cryptographySettings>
    </mscorlib>
</configuration>

这允许我的代码看起来像这样:

using (var h1 = HashAlgorithm.Create("Tiger192"))
{
   ...
}

并且在我的代码中根本不依赖于Jcs.Tiger.dll程序集,无论是硬还是软。