使用WIX,Windows Installer在Win 10上失败但在Win 7上失败
我最近被分配更新我们的项目安装程序以在Windows 10上运行,我对如何使其工作有点不知所措.我没有安装经验,我不仅熟悉整个过程,还熟悉我们的项目如何处理它.
截至目前,安装程序在我们的Windows 7 VM上运行完美,但在Windows 10 VM上运行时,它会在接近结束时失败并开始回滚.我已经把它吐出一些日志文件,我正在挖掘它们但是相当丢失. 我跟踪了这??一点: MSI (s) (B0:F4) [17:39:02:883]: Note: 1: 1708 MSI (s) (B0:F4) [17:39:02:883]: Note: 1: 2205 2: 3: Error MSI (s) (B0:F4) [17:39:02:883]: Note: 1: 2228 2: 3: Error 4: SELECT `Message` FROM `Error` WHERE `Error` = 1708 MSI (s) (B0:F4) [17:39:02:883]: Note: 1: 2205 2: 3: Error MSI (s) (B0:F4) [17:39:02:883]: Note: 1: 2228 2: 3: Error 4: SELECT `Message` FROM `Error` WHERE `Error` = 1709 MSI (s) (B0:F4) [17:39:02:883]: Product: GPEP -- Installation failed. 接近最终似乎发生在安装程序似乎失败时或附近. 下一行最后有这个: Installation success or error status: 1603. 我调查了错误,发现了这个:Error 1603 我正在调查该页面上的解决方案,但所有这些都应该是有序的.我们以相同的方式运行安装程序,在Win 10和Win 7 VM上具有相同的权限. 我怀疑这将是足够的信息来获得任何具体的反应,所以我正在寻找建设性的建议,如何看待以及如何解决这个问题.我有更多可以发布的详细信息,但信息量如此之多,我不知道如何找出真正相关的内容.
添加这个作为答案 – 评论太长了,我认为这也是正确的答案.如果您阅读此答案,请参阅上面的评论,以获取
Rob Mensching(WiX的创建者)的非常好的MSI日志文件调试技巧 – 以及如何确保所有条目通过启用“刷新到日志”进行崩溃而使其进入日志文件自定义操作.
答案 对像Powershell这样的缺失运行时的依赖肯定会触发回滚. MSI为某些脚本自定义操作(active scripting)托管自己的运行时.例如VBScript和JavaScript.为了可靠部署,建议使用的所有自定义操作都是自包含的最小依赖性C dll或可执行文件(win32)或(不太理想的)VBScript或JavaScript(如果使用Installshield,则甚至是Installscript – 请参阅下面的详细信息). 我的争议观点:用于可靠性和健壮性的最糟糕的自定义操作是.NET二进制文件,需要特定版本的.NET框架.这也适用于PowerShell – 它不仅是托管代码,还是脚本.我很想说这些技术不应该用于部署,但是如果你需要使用PowerShell,你必须至少在安装开始时添加“验证PowerShell安装”自定义操作,并优雅地退出如果PowerShell不可用,则显示(和/或记录)正确的错误消息. 这是真正答案的结束:-).以下是一些“冗长的思考”,以防您正在制作一般分发包(而不仅仅是您公司内部部署的包).如果我是你,我会读它,即使你只在内部部署,PowerShell自定义操作可能是一个口径的酿造部署问题. 托管代码和脚本都存在问题. PowerShell实际上是有效的. Here is Rob Mensching’s blog on why script custom actions are bad.基本上:脚本是脆弱的,它们缺乏语言功能,很难调试,反病毒产品通常会阻止它们.阅读博客.并且here is Aaron Stebner’s blog on why managed code is bad.当您依赖.NET框架的存在时,基本上不能保证适当的运行时环境. 详细的冥想 我不确定Win7和Win10上标准安装的是什么.如果您要部署为公司的“内部包”,我认为只需添加对PowerShell存在的可靠检查,然后如果找不到PowerShell则中止有意义的错误消息.意见警告:但是整体.NET二进制文件和PowerShell脚本是可靠性最差的自定义操作.我绝不会将它们用于针对不同计算机的设置. 如果您要将MSI一般分发到任何地方的任何计算机,我会花时间将PowerShell脚本转换为其他内容.最好是C dll – 我觉得最可靠.没有依赖性或依赖的层.如果你一直使用Installshield,它甚至可以接受InstallScript(它可以在没有预先安装的运行时运行 – 这显着提高了它的可靠性和实用性 – 虽然语法相当陈旧,但它是一种迟钝的语言.公平地说,不是被低估 – 它完成了工作,并且比C更简单. JavaScript和VBScript自定义操作甚至可以用于一般分发到任何计算机的MSI,但仍然不推荐使用.我倾向于仅将它们用于“内部公司部署”包.这些可以是标准化的,关键的是脚本对其他系统管理员和打包者是透明的.他们可以查看和检查安装过程中正在执行的操作.这通常是可取的和one of the key benefits of MSI for corporate deployment,但有时您需要编译二进制来隐藏实现细节(例如,当您验证许可证密钥时).然后,任何类型的脚本都不能使用 – 显然.通过透明并嵌入在MSI中(因此,完整的,运行的源始终可用),它可以帮助不同的应用程序打包者在需要时能够获取其他人的工作.在部署团队中总有人可以调试脚本 – 但很少有人知道正确的C.在内部应用程序的开发人员在没有太多部署知识的情况下制作自己的MSI文件的公司中,脚本编写可能完全误入歧途并导致非常困难的部署问题.通常需要的是对应用程序本身的小改动,以允许更可靠的部署.例如,应用程序应该执行自己的启动配置 – 这些都不应该在安装脚本中完成,但许多开发人员会这样做. 使用脚本自定义操作是有争议的.如果您询问2位开发专家,您将获得4个意见.在我看来,“白盒子”自定义动作(脚本)对于企业用途是有益的,如果他们做一些不常见的特定事情,那么人们可以看到正在发生的事情.对于一直需要的东西,公司应该使用MSI文件中的自定义表驱动编译的C dll,并提供完整的QA和回滚支持 – 这对于所有脚本自定义操作通常总是缺失(这对于实行). “数据驱动”(自定义表)C自定义操作具有最小的依赖性作为其最大优势,并且它也是透明的(将发生什么是透明的,但实际的实现是编译和隐藏的 – 这也可以提高安全性). WiX工具包提供了这样一个带有用C编写的回滚支持的自定义动作DLL.它应该解决企业部署所需的大多数自定义任务.所有这一切都超出了你的问题 – 只是一个题外话:-). 如果我猜测我会说Windows Installer可能会更新为能够为Powershell托管自己的运行时 – 但这只是猜测.我不确定技术细节 – 似乎需要整个.NET运行时?如果你问我,我仍然更喜欢JavaScript到PowerShell脚本,但我意识到你可能已经承诺将PowerShell作为公司标准?此外,总是喜欢JavaScript而不是VB脚本,因为它看起来像异常处理(VB脚本完全缺乏).更新:实际测试表明VBScript实际上更适合与MSI一起使用而不是Javascript.例如:我在使用Javascript访问MSI API时遇到了一些模糊的问题. MSI本身可能使用VBScript进行了更多测试,而不是使用Javascript进行测试.老实说:两种“语言”都有严重的局限性,而且两者都难以调试. Rob Mensching,Chris Painter,Phil Wilson,Bob Arnson以及其他人(我不确定Stefan Kruger’s在脚本上的位置,或者Robert Dickau的观点) – 会因此而杀了我,但这里是JavaScript自定义动作的模板(未经测试)由我,但看起来不错):How to debug an MSI Custom Action that is implemented in Javascript?.如果我可以脱口而出:目前任何东西都比PowerShell更好 – 甚至是JavaScript. 请放心,我浪费了大量时间调试极其糟糕的VB Script自定义操作.可能是用于部署的最无能和最无用的语言. On Error Resume Next进行错误处理?它不会变得更糟.我通常只使用脚本进行只读操作和设置属性操作. 也许我们会看到VB脚本被弃用,PowerShell在适当的时候被添加为可行的MSI脚本选项?在使用的所有操作系统至少安装了.NET框架的基准版本之前,我不会认为这是安全的 – 即便如此,我相信策略可以锁定特定版本的.NET.您是否想要一个突然无法卸载的软件包,因为.NET框架的目标版本不再可用?解决这样一个问题可能是一项令人难以置信的工作量 – 特别是对于拥有大型软件包(数千个软件包,数千台机器)的公司而言. 推荐的自定义操作实现 我写了自定义操作实现的“建议”摘要.它变得很长,没有多说 – 我删除了它.相反,这是我的自定义操作实现首选项列表(按降低稳健性和可靠性的顺序): 更新2018年5月:不再推荐Javascript超过VBScript. > C dll 概要: >对我来说,PowerShell在编写绝对是最糟糕的选择时.它既是托管代码(不可靠的运行时),也是脚本自定义操作(调试不佳). >如上所述,脚本应该仅在极少数情况下使用,并且win32 C dll或WiX的自定义操作dll应该用于人们倾向于重复使用的所有常见脚本任务.只有在需要完成工作时才能使用脚本. 我确信的一件事是,托管代码自定义操作的可用性将导致人们在他们的设置中执行太多的事情,这些事情永远不应该在设置中完成(丰富的API,相对简单的编码).这都是因为编码更容易,更快,而且有问题的开发人员可能缺乏对如何正确部署的理解.这不可避免地导致过度使用各种自定义操作,并且反过来主要部署问题如the complexity of custom actions触发意外错误. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- windows-10 – 如何禁用Windows 10中的Winscard Discovery?
- 从WIN32应用程序使用的C#COM DLL调用Java代码?
- windows-server-2008 – 终端服务器2008:安装16位应用程序
- windows – WDM驱动程序,KMDF驱动程序和UMDF驱动程序有什么
- Windows server 1709(不含UI)模板部署
- 调试 – Windows Phone 7:从计算机控制手机
- active-directory – 为什么我的用户帐户无法删除Powershel
- windows – 如何获取通知区域图标列表?
- winapi – SetWindowText慢,Win32 C.
- 我们如何远程管理我们的Windows 7笔记本电脑“车队”?
- win10能点开开始菜单但是不能点里面的功能
- diskmanagement – Windows 2012 R2中的磁盘管理
- windows-server-2012-r2 – Windows Server 2012
- windows-server-2003 – 确定谁以管理员权限运行
- windows-server-2012 – 全新安装Windows Server
- Windows – 如何最小化我的蝙蝠文件中的命令提示
- 窗户 – 苏多!!在PowerShell中等效
- microsoft-office-365-将office365企业办公室201
- windows-10 – 签署代码后摆脱智能屏幕警告多长时
- windows – 是否可以通过WAN链接进行实时或同步复