我需要在ASP.NET应用程序中使用不同的数据库连接字符串和SMTP服务器地址,具体取决于它是在开发环境还是生产环境中运行的。
该应用程序通过WebConfigurationManager.AppSettings属性从Web.config文件读取设置。
我使用Build / Publish命令通过FTP将应用程序部署到生产服务器,然后用正确的手动替换远程Web.config。
是否有可能以某种方式简化部署过程?谢谢!
我需要在ASP.NET应用程序中使用不同的数据库连接字符串和SMTP服务器地址,具体取决于它是在开发环境还是生产环境中运行的。
该应用程序通过WebConfigurationManager.AppSettings属性从Web.config文件读取设置。
我使用Build / Publish命令通过FTP将应用程序部署到生产服务器,然后用正确的手动替换远程Web.config。
是否有可能以某种方式简化部署过程?谢谢!
Answers:
在Visual Studio 2010及更高版本中,您现在可以根据构建配置将转换应用于web.config。
创建web.config时,可以在解决方案资源管理器中展开文件,然后将看到两个文件:
它们包含可用于
有关更多信息,请参见用于 MSDN上的Web应用程序项目部署的Web.config转换语法。
尽管没有官方支持,也可以对非Web应用程序app.config
文件进行相同类型的转换。有关如何修改项目文件以向msbuild添加新任务的信息,请参见Phil Bolduc博客。
这是对Visual Studio Uservoice的长期要求。
Visual Studio 2010及更高版本的扩展 “ SlowCheetah ”可用于为任何配置文件创建转换。从Visual Studio 2017.3开始,SlowCheetah已集成到IDE中,并且代码库由Microsoft管理。此新版本还支持JSON转换。
Web.Debug.Config
和Web.Release.Config
,则可能需要右键单击Web.Config
并单击Add Config Transforms
。
<appSettings>
web.config中的标记支持file属性,该属性将使用其自身的一组键/值加载外部配置。这些将覆盖您在web.config中拥有的任何设置或将其添加到其中。
我们通过在安装时使用与站点安装环境相匹配的文件属性修改web.config来利用此优势。我们通过在安装程序上进行切换来实现。
例如;
<appSettings file=".\EnvironmentSpecificConfigurations\dev.config">
<appSettings file=".\EnvironmentSpecificConfigurations\qa.config">
<appSettings file=".\EnvironmentSpecificConfigurations\production.config">
注意:
restartOnExternalChanges
会将这些文件视为web.configs。资料来源:learnable.com/books/…–
您是否看过Web部署项目?
如果您不在2008年,也有VS2005的版本。
我也想知道。这有助于为我隔离问题
<connectionStrings configSource =“ connectionStrings.config” />
然后,我保留一个connectionStrings.config以及一个“ {host} connectionStrings.config”。这仍然是一个问题,但是如果您针对两个环境中不同的部分执行此操作,则可以部署和版本化相同的web.config。
(顺便说一句,我不使用VS。)
我使用NAnt构建脚本部署到我的不同环境。我让它通过XPath修改配置文件,具体取决于部署到的位置,然后使用Beyond Compare将它们自动放入环境中。
只需花一两分钟即可完成设置,但只需执行一次。然后批处理文件接管,而我又去喝杯咖啡。:)
这是我在上面找到的一篇文章。
您也可以将其设为构建后步骤。设置除调试和发行版外的新配置“ Deploy”,然后将构建后步骤复制到正确的web.config上。
我们对所有项目都使用自动构建,并且使用这些构建脚本来更新web.config文件以指向正确的位置。但是,如果您要执行VS中的所有操作,那将无济于事。
这是使用machine.config的巨大好处之一。在我的上一份工作中,我们拥有开发,测试和生产环境。我们可以将machine.config用于连接字符串之类的东西(连接到适当的dev / test / prod SQL计算机)。
如果您无权访问实际的生产机器(例如,如果您在共享主机上使用托管公司),那么这可能不是您的解决方案。