错误描述
我们的网站通过WIX生成的MSI安装到IIS上。为了在ApplicationHost.config中加入我们网站专用的Advanced Logging的配置信息,我们用了XmlConfig来修改ApplicationHost.config。结果MSI安装报错:需要修改的XML节点也就是<site name="our web site">不存在。
分析
我们在调研中发现,WIX使用了一个deferred CA(Custom Action)- ConfigureIIs在IIS中创建和配置网站。WIX使用了另外一个CA - SchedXmlConfig来处理XmlConfig。SchedXmlConfig是Immediate的,它会在安装过程中动态地安排另外两个deferred CA - ExecXmlConfigRollback和ExecXmlConfig在合适的时机执行,这两个CA就是真正修改XML文件的。但是,在默认的InstallExecuteSequence中,SchedXmlConfig总是在ConfigureIIs之前执行,并且会把ExecXmlConfigRollback和ExecXmlConfig安排在ConfigureIIs之前执行。所以,当WIX去修改ApplicationHost.config时,我们的网站还没有创建出来呢,自然就会报错了。
解决方法
我们注意到SchedXmlConfig总是会把ExecXmlConfigRollback和ExecXmlConfig安排在它自己之后运行,因此,解决的方法就是把SchedXmlConfig放到ConfigureIIs之后执行。
我们可以用Orca.exe来直接修改编译生成的MSI文件。但更好的办法是用<Custom>标记在我们的WIX代码文件中修改SchedXmlConfig的执行时机:
<InstallExecuteSequence>
<Custom Action="SchedXmlConfig" After="ConfigureIIs"/>
</InstallExecuteSequence>
当然了,这个办法可以用来修改任意一个WIX预定义CA的默认执行时机。