我有一个用 WiX 编写的简单 msi,它安装了本机 NT 服务。在我对 msi 进行一些更改后,它在 StartServices 标准操作中失败,并出现错误“服务无法启动,请验证您是否有足够的权限”。如果我按忽略并手动启动服务,那么它会成功启动。问题绝对不在于权限不足。如何诊断/调试此类问题?Windows Installer 的详细日志似乎不包含任何有用的信息。
2 回答
安装程序不会有任何有用的信息,因为错误仅由安装程序显示。这是我的处理方法。
注释掉 ServiceControl 元素,这样安装程序就不会尝试启动服务。运行安装程序并完成所有操作。手动启动服务。
如果服务启动,这表明某种类型的竞争条件。一种常见情况是服务依赖于安装到 GAC 或 WinSXS 的文件。安装程序使用 PublishAssemblies 标准操作将这些文件放在那里。但是,由于 GAC 和 WinSXS API 不支持事务安装,PublishAssemblies 会等到提交阶段才能执行工作。这是在安装程序尝试启动服务之后。另一个常见的情况是,如果您有一些自定义操作正在安装或配置服务所需的内容,并且您在安装后期才这样做。
如果服务仍然无法启动,这通常会排除竞争条件。您必须对服务本身进行概要分析。使用depends、ildasm(如果是.net)和processexplorer(filemon / regmon)等工具来尝试发现缺少的依赖项是什么。更新安装程序,然后冲洗并重复。
如您所见,Windows Installer 在启动服务失败时不会提供有用的信息。但是,当显示对话框时,机器处于完美状态,可以确定发生了什么问题。因此,与其取消安装,不如开始调试。尝试启动该服务,看看是否可以为您提供更多信息。如果没有,请打开调试器并前往城镇。
我基本上遵循这个FireGiant 知识库文章中描述的过程。这是找出服务无法启动的最直接方法。太糟糕了,Windows Installer 本身无法提供更好的消息。