我需要在我的ASP中使用不同的数据库连接字符串和SMTP服务器地址。NET应用程序,这取决于它在开发环境或生产环境中运行的位置。
应用程序从Web读取设置。配置文件通过WebConfigurationManager。AppSettings财产。
我使用Build/Publish命令通过FTP将应用程序部署到生产服务器,然后手动替换远程Web。配置正确。
是否有可能以某种方式简化部署过程?谢谢!
我需要在我的ASP中使用不同的数据库连接字符串和SMTP服务器地址。NET应用程序,这取决于它在开发环境或生产环境中运行的位置。
应用程序从Web读取设置。配置文件通过WebConfigurationManager。AppSettings财产。
我使用Build/Publish命令通过FTP将应用程序部署到生产服务器,然后手动替换远程Web。配置正确。
是否有可能以某种方式简化部署过程?谢谢!
当前回答
你也可以使用扩展“配置转换”与“SlowCheetah”一样,
其他回答
web中的<appSettings>标签。Config支持一个file属性,该属性将使用它自己的一组键/值加载外部配置。这些将覆盖你在你的网页中的任何设置。配置或添加到它们。
我们通过修改我们的网络来利用这一点。在安装时使用与站点将要安装到的环境相匹配的文件属性进行配置。我们通过安装程序上的一个开关来做到这一点。
eg;
<appSettings file=".\EnvironmentSpecificConfigurations\dev.config">
<appSettings file=".\EnvironmentSpecificConfigurations\qa.config">
<appSettings file=".\EnvironmentSpecificConfigurations\production.config">
注意:
对该属性指定的.config的更改不会触发asp.net工作进程的重新启动
这是使用machine.config的巨大好处之一。在我的上一份工作中,我们有开发、测试和生产环境。我们可以用机器。配置连接字符串(到相应的dev/test/prod SQL机器)。
如果您无法访问实际的生产机器(例如,如果您在共享主机上使用托管公司),那么这可能不是一个解决方案。
你也可以使用扩展“配置转换”与“SlowCheetah”一样,
在一个有4个环境(开发、测试、登台和生产)的项目中,我们开发了一个系统,其中应用程序根据部署到的机器名称选择适当的配置。
这对我们来说很有效,因为:
管理员可以在不涉及开发人员(需求)的情况下部署应用程序,也不必摆弄配置文件(他们讨厌配置文件); 机器名称遵循约定。我们使用正则表达式匹配名称,并将其部署到一个环境中的多台机器上;而且 我们对连接字符串使用了集成安全性。这意味着我们可以在设计时在配置文件中保留帐户名,而不泄露任何密码。
在这种情况下,它很适合我们,但可能并不适用于任何地方。
我也想知道。这有助于我隔离问题
<connectionStrings configSource="connectionStrings.config"/>
然后我保留一个connectionStrings。config以及“{host} connectionStrings.config”。这仍然是一个问题,但如果您对两个环境中不同的部分执行此操作,则可以部署和版本相同的web.config。
(顺便说一下,我不用VS。)