- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
最近,我被指派更新我们的项目安装程序以在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.
最佳答案
将其添加为答案-注释太长,我认为这也是正确的答案。如果您阅读此答案,请也从上方查看我的评论,以获得Rob Mensching(WiX的创建者)非常好的MSI日志文件调试技巧-以及如何通过启用崩溃的“刷新日志”功能来确保所有条目都进入日志文件自定义操作。
答案
对缺少像Powershell这样的运行时的依赖肯定会触发回滚。 MSI为某些脚本自定义操作(active scripting)托管其自己的运行时。例如VBScript和JavaScript。为了可靠地进行部署,建议所有使用的自定义操作要么是自包含的最低依赖性C++ dll或可执行文件(win32),要么是(不太理想的)VBScript或JavaScript(如果使用Installshield,甚至是Installscript-请参见下面的详细信息)。
我的有争议的观点:用于可靠性和健壮性的最差的自定义操作是需要特定版本.NET框架的.NET二进制文件。这也适用于PowerShell-它不仅是托管代码,而且是脚本。我很想说这些技术不应该用于部署,但是如果您需要使用PowerShell,则必须至少在安装开始时添加一个“验证已安装PowerShell”自定义操作,并以如果PowerShell不可用,则会显示(和/或记录)正确的错误消息。
真正的答案到此为止:-)。如果您要制作一个用于一般发行的软件包(而不仅仅是您自己公司内部部署的软件包),则下面是一些“冗长的沉思”。如果我是您,即使您仅在内部进行部署,我也会读它, PowerShell自定义操作可能是 Eloquent 的酝酿部署问题。
托管代码和脚本都有问题。 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 Framework时,不能保证您会拥有适当的运行时环境。
详细的沉思
我不确定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所希望的,但有时您需要编译的二进制文件才能隐藏实现细节(例如,当您验证许可证 key 时)。这样就不能使用任何类型的脚本-显然。通过透明并且还嵌入到MSI中(因此始终可以获取完整的运行源代码),它可以帮助不同的应用程序包装商在需要时承担其他人的工作。在部署团队中,总会有人来调试脚本-但很少有人可能知道正确的C++。在内部应用程序开发人员在没有太多部署知识的情况下制作自己的MSI文件的公司中,脚本编写可能会完全误入歧途,并导致非常困难的部署问题。通常,需要对应用程序本身进行小的更改以允许更可靠的部署。例如,应用程序应该进行自己的启动配置-不应在安装脚本中完成所有操作,但是许多开发人员都可以这样做。
使用脚本自定义操作存在争议。 如果您询问2位开发专家,您将获得4条意见。在我看来,“白框”自定义操作(脚本)如果做一些不常见的特定操作,则可以用于公司,这样人们就可以看到发生了什么。对于一直需要的内容,公司应在MSI文件中创建由自定义表驱动的经过编译的C++ dll,并提供全面的质量检查和回滚支持-所有脚本自定义操作通常都缺少这种东西(实行)。 “数据驱动”(定制表)C++定制操作具有最大的优势,即具有最小的依赖关系,并且也是透明的(将发生的事情是透明的,但是实际实现被编译和隐藏了,这也可以提高安全性)。 WiX工具包提供了这样的自定义操作dll,并以C++编写了回滚支持。它应该解决企业部署所需的大多数自定义任务。 尽管这一切都超出了您的问题-只是题外话:-)。
如果我猜到了,我会说Windows Installer可能已更新为能够托管Powershell自己的运行时-但这只是猜测。我不确定技术细节-似乎需要整个.NET运行时?如果您问我,相对于PowerShell脚本,我仍然会更喜欢JavaScript,但我知道您可能致力于将PowerShell作为公司标准?同样,总是比VB脚本更喜欢JavaScript,因为它看起来像异常处理(VB Script完全缺少)。 更新:实际测试表明,与Javascript相比,VBScript实际上更适合与MSI一起使用。例如:在使用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 Framework的目标版本不再运行而突然无法卸载的软件包? 解决这个问题可能是一项令人难以置信的工作,尤其是对于拥有大量包装 Assets (数千个包装,数千台机器)的公司而言。
推荐的自定义操作实现
我撰写了有关自定义操作实现的“建议”摘要。它长篇幅不多说-我删除了它。相反,这是我的自定义操作实现首选项的列表(以降低健壮性和可靠性的顺序):
更新,2018年5月:不再推荐基于VBScript的Javascript。
关于windows - Windows Installer在Win 10上失败,但在使用WIX的Win 7上失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46045359/
我一直在尝试查找文章或发布列出 WiX (Windows Installer XML)/WiX 工具集的功能限制的文章,但均未成功。使用 WiX 几个星期后,我至少能想到两个 限制 在最新的 RTM
我们在 SomeDialog.wxs 文件中有一个 WiX 片段,它会提示用户输入一些信息。它在 InstallerUI.wxs 文件中控制对话框顺序的另一个片段中被引用。当然,Product.wxs
我们有多个配置文件。根据所选的环境,正确的文件将被复制,其余文件应被删除。 我正在使用RemoveFile,但是不会删除任何内容,或者可能是我没有正确使用它。复制所有文件后,有人可以举一个例子在安装过
我正在为现有产品编写 MSI。在以前的版本中有一个自定义操作,它不仅限于在安装时运行,现在在使用 MajorUpgrade 卸载时失败。 新安装程序中是否有任何方法可以告诉 WiX 在卸载时跳过该特定
我需要在安装之前检查 .NET Framework。我添加了这个 文件的开头包含 并在链接时出现错误 error LGHT0094 :
如果在功能选择树中选择了另一个功能,是否有任何方法可以强制安装特定功能?那就是没有让功能成为它们依赖项的子项? 最佳答案 是的,这应该是可能的,如果您在 Feature 元素下使用 Condition
有没有办法在 WiX 中强制自动登录? 目前,要生成日志,我需要使用此参数执行我的包: application.msi /l*v log.txt 我想在 中找到一个方法标记 - 例如 - 强制日志始
我正在为我的项目创建一个 WIX 模板,以确保相对标准的布局。 我已经使用 定义了一个变量来引用主应用程序其中 MyApp 是引用项目的名称。然后,我使用 MainApp 变量在 .wxs 和 .w
我有一个名为 MyProject(P2P) 的 visual studio 项目,它一直运行良好。 现在我正在使用 Wix 3 将这个项目打包到 MSI 中,其中一个步骤是编写组件节点:
我正在使用Wix 3.6。我有一个问题,在卸载时是否打开了任何窗口并显示在任务栏中(此窗口是我试图卸载的msi的一部分),它显示了一个对话框,要求用户关闭应用程序(“在继续安装之前,应关闭以下应用程序
我需要澄清 *.wxs 文件中的目录结构。据我所知,它将文件安装在我们在目录元素中指定的目录中。它还有其他用途吗? 如果它确实描述了将安装产品的目录结构,那么如果用户在安装程序中有浏览选项会发生什么。
我们已经为我们的应用程序创建了 WIX 安装程序。我们面临的问题是: 我们已经定义了两个不同的自定义操作(比如 ActionForInstall 和 ActionForUninstall),我们希望在
我有一个应用程序安装程序,无论版本号如何,都需要通过任何现有版本进行安装。 相反,我有一个安装程序,不断说我需要添加/删除程序。对于我的测试人员而言,这是非常令人沮丧的行为,因为这只会在没有真正原因的
我正在使用VS 2010创建一个由Wix安装的程序,并且已经准备好product.wxs。 在我的wxs文件中,我有类似以下的目录定义:
关注 example here ,我在 ProgramMenuFolder 中添加了一个快捷方式启动我的应用程序。 (我的代码实际上更简单,因为我不需要额外的文件夹。)
即使在重新启动后,服务仍然存在,即使可执行文件消失了。我正在使用 WIX 版本 3.0.5419.0 安装 Windows 服务工作正常。卸载它似乎什么也没做。卸载日志文件的部分
我正在尝试配置 WiX 设置和库,以便将库中文件之一的版本用作设置中的 Product/@Version。 背景 在本地定义文件的设置中,这相对简单,因为假设组件项目被 WiX 项目引用然后配置:
我想在wix项目生成的msi文件的文件名中包含一些动态部分。这个动态部分应该由变量控制,这些变量是我的wix项目的一部分,并且应这样声明: 有谁知道将wix变量的值发送给链接器以将其用作输出文件名的
我真的觉得我不必为了获得这样的基本信息而在SO上提问,但是我在任何地方都找不到可靠的消息来源。 WiX v4是否已发布?开发中?在Beta中?还在设计中? 如此看来,许多人似乎已经在使用WiX v4。
如果注册表项 HKEY_CURRENT_USER\Control Panel\International\LocaleName 的值为 de-DE,我希望将 INSTALL_DE 属性值设置为 1。
我是一名优秀的程序员,十分优秀!