1. machine.config 文件中的restartOnExternalChanges属性,指定对外部配置包含文件进行更改后是否需要重新启动应用程序。设置为false即不会重启应用程序。注意是外部文件,而非web.config文件本身。
修改web.config肯定还会重新启动应用程序域的,Web还是会断线,有点像百货公司把大家都赶出来,再开门让大家进来。
configSource属性对web.config进 行拆分。如
<profile configSource="profile.config" restartOnExternalChanges="true" />
默认情况下,如果特定配置节的 config文件内容更改,iis是察觉不到的,所以不会重启程序池。 假如你需要在 特定配置节config文件修改后能让iis自动察觉到并进行重启, 可以利用 RestartOnExternalChanges属性,设置为true。
2. 另外其他会重启应用程序的条件
上传DLL 重启服务器 重启iis 有目录被删除时
3. 关于拆分web.config文件分而治之从以下几点考虑:
a. 经常发生变化
某些配置节我们在开发时经常要修改或更新,如果能单独拉出来进行配置,这样修改时就不必碰web.config。 不同环境下的web.config都引用了同一个配置节config,所以这样的修改只需要做一次,而不必去修改所有环境的web.config。
b. 内容行数特别多
有时候web.config里有些配置节 都是一大坨一大坨的,影响了web.config整体的审美观。 我们完全可以把这些大 坨的配置节内容单独抽取出来, 这样一来,web.config就简洁多了,也便于阅读 。 c. 不同环境下,配置节内容是不一样的
我们经常会有这样的配置节, 对于这种情况,我们完全可以考虑拆分出来, 并且生成不同环境下的配置文件。 而不同环境下的web.config只要引用对应环境的配置节文件即可。 即使环境发生了变化, 我们也不需要去动web.config, 只要去修改相应环境下配置节文件即可。
当然,以上这三种特征不是互斥的 ,很可能某一配置节含有以上两种或三种特征。这些配置节更需要我们认真对待,通过多重策略来进行拆分。
4. 分而治之怎么能各得其所,命名规则上来区分
如果web.config很复杂, 那拆分后的结果可能会多出一堆***.config文件, 所以我们需要一套简单有效的命名规范来管理好这么多配置文件。
a. Web.config:在不同环境下的文件 可以命名为Web.local.config, Web.beta.config, Web.release.config
b. 特征1,2配置节文件: 可以取配置节的名字来命名文件, 比如profile.config, 规范一下应该是Web.profiling.config, 类似还有Web.httpHanders.config, Web.httpModules.config等等。
c. 特征3配置节文件: 假如有个dbConfig配 置节(不同环境下的数据库连接配置), 我们可以命名为 Web.dbConfig.local.config, Web.dbConfig.beta.config, Web.dbConfig.release.config。
通过分而治之的管理和规范的命名, 我们就可以轻松地进行配置管理,而不必整天面对那一大坨 看似一样 又有些不太一样配置节点。1-1-6*2-3-2*6-3*8-9