ts2009 发表于 2015-8-15 08:30:55

Config文件修改与IIS重启应用程序域(转)

  



  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
页: [1]
查看完整版本: Config文件修改与IIS重启应用程序域(转)