gpt4 book ai didi

c# - 禁用 InstallFiles 的自动回滚

转载 作者:太空宇宙 更新时间:2023-11-03 21:31:49 26 4
gpt4 key购买 nike

我已经使用 WIX-Toolset 3.6 实现了我的第一个 MSI 安装程序,其中包括用于 BackupInstallation 的自定义操作回滚

备份和安装工作正常,但我的回滚自定义操作有问题。我已经这样定义了我的自定义操作:

<!-- Custom actions -->
<CustomAction Id="CA_Install" Return="check" BinaryKey="BIN_CaLibrary" Execute="deferred" DllEntry="CaInstall" />
<CustomAction Id="CA_Rollback" Return="check" BinaryKey="BIN_CaLibrary" Execute="rollback" DllEntry="CaRollback" />
<CustomAction Id="CA_Backup" Return="check" BinaryKey="BIN_CaLibrary" Execute="immediate" DllEntry="CaBackup" />
<CustomAction Id="CA_SetTargetDir" Return="check" BinaryKey="BIN_CaLibrary" Execute="immediate" DllEntry="CaSetTargetDir" />
<CustomAction Id="CA_SetTargetDirAndInstallTypeForInstall" Return="check" Property="CA_Install" Value="InstallType=[INSTALLTYPE];TargetDir=[TARGETDIR]" />
<CustomAction Id="CA_SetTargetDirForRollback" Return="check" Property="CA_Rollback" Value="TargetDir=[TARGETDIR]" />

<!-- Linking custom actions to the install sequence -->
<InstallExecuteSequence>
<Custom Action="CA_SetTargetDir" Before="AppSearch" />
<Custom Action="CA_Backup" After="CA_SetTargetDir" />
<Custom Action="CA_SetTargetDirForRollback" Before="CA_Rollback" />
<Custom Action="CA_SetTargetDirAndInstallTypeForInstall" Before="CA_Install"/>
<Custom Action="CA_Rollback" Before="CA_Install"/>
<Custom Action="CA_Install" Before="InstallFinalize" />
</InstallExecuteSequence>

在我的 CA_Backup 中,我总是使用旧版本的应用程序创建一个备份目录(即使安装成功)。当我的 CA_Install 遇到异常时,安装程​​序会跳转到我自己的回滚自定义操作 CA_Rollback。在此自定义操作中,我删除了 TARGETDIR 中的所有文件并从备份目录中重新生成这些文件。它确实做了它应该做的事情,但在 CA_Rollback 之后,Wix-Installer 会自动回滚其他自定义操作,如 InstallFiles。因此它删除了之前从我的 CA_Rollback 中的备份目录复制的所有文件。

是否可以禁用 InstallFiles 自定义操作的自动回滚?或者我的问题还有其他解决方案吗?

同样奇怪的是CA_Rollback的ProgressText不是我定义的,而是WiX-Framework的标准文本。

<ProgressText Action="CA_SetTargetDir">Getting Installation-Type...</ProgressText>
<ProgressText Action="CA_Backup">Creating Backup-Directory...</ProgressText>
<ProgressText Action="CA_Install">Updating Application...</ProgressText>
<ProgressText Action="CA_Rollback">Rollback the Application...</ProgressText>

因此,当安装程序跳转到 CA_Rollback 时,ProgressText 不是“回滚应用程序...”,但在其他自定义操作(CA_SetTargetDir、CA_Backup、CA_Install)中,ProgressText 显示为已定义.

编辑:
我找到了 DisableRollback Action我想在我的 InstallExecuteSequence 中这样使用它:

<DisableRollback After="CA_Rollback" />

所以我想运行我自己的回滚 CA_Rollback,但想禁用其他自定义操作的自动回滚。但是当我包含它时,根本没有回滚。

最佳答案

你的问题对我来说有点不清楚——我很困惑你到底在问什么,以及你为什么以这种方式实现回滚。但是,这是一个一般性的答案:

回滚支持Windows Installer 的内置功能,您根本不需要实现此功能。您可能需要一个回滚自定义操作来补充对目标系统进行更改的自定义操作。请参阅下面的信息。

在安装软件期间替换的文件,以及注册表项、ini 文件设置和其他在 MSI 表中正确定义的设置,都直接存储在系统驱动器上的隐藏文件夹中(通常 C :\Config.MSI) 在安装过程中。这些文件的扩展名为 .RBS.RBF - Rollback Script Files - 如果在安装过程中发生错误,可以将系统恢复到之前的状态,除非在自定义操作中进行任何更改。

自定义操作 是特殊的,因为它们根据定义是非标准的,因此没有内置的回滚支持。为了回滚这些更改,您需要编写免费的回滚自定义操作来撤消原始自定义操作所做的操作。这可能非常复杂,需要仔细安排、实现和测试。请注意,在不进行任何系统更改的情况下执行检查、属性检索或其他任务的只读自定义操作不需要回滚。使用这些非侵入性自定义操作可能非常有效。我特别喜欢使用这些自定义操作在一个脚本中收集许多操作,以便于其他设置开发人员进行检查。 MSI 的运行时行为就像一个复杂的 watch - 许多交互和计时问题都是可能的,这使得快速概览变得困难。可能需要在 2-3 个不同的、看似无关的地方进行更改才能获得所需的行为。脚本是连续的,可以注释以便更容易理解,并且可以在一个位置进行关键更改。对于团队合作,我发现这些脚本必不可少。

重要的是要指出自定义操作往往是不必要的,因为已经使用内置的 Windows Installer 功能或 WIX 功能以更可靠的方式实现了相同的功能。 Wix is an XML based toolkit 允许从 XML 源文件编译 MSI 文件。该工具包由 Rob Mensching(曾是 Microsoft 的 Windows Installer 团队成员)编写,高度可靠、高度可定制,并且充满高级和简单的类似功能。

尽可能避免不必要的自定义操作的重要性怎么强调都不为过。检查 Windows Installer 或 Wix 是否支持它。

MSI 完全支持处理 ini 文件设置、字体、环境变量、注册表项、COM 信息、快捷方式、文件扩展名、启动条件、GAC 安装、ODBC 等的合并...

WIX 进一步支持非常高级的功能,例如 SQL 服务器扩展、IIS 安装和配置、性能计数器、DirectX 检查和其他游戏相关任务、.NET native 图像生成、COM+、驱动程序、防火墙规则、PowerShell 扩展、应用程序关闭、用户管理、组、共享等等。有些涉及处理,但比您自己的自定义操作可靠得多。下载 latest version of WIX 并阅读帮助文件 Wix.chm - Wix 架构引用部分。

关于c# - 禁用 InstallFiles 的自动回滚,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23778722/

26 4 0