3

在我们的自动化构建中,我开始出现相当奇怪的行为。我有一个非常简单的 Windows 服务 .msi(内置于 Visual Studio 2010),它在我们的中央构建/存储库服务器上编译,上传到我们的开发服务器,然后从构建/存储库服务器远程安装(命令行通过 ssh 使用 plink)在开发服务器上。

这已经工作了很长时间,直到最近自动化构建开始失败 100% 的时间。msi 的详细安装日志表明“已安装此产品的较新版本”。我远程进入开发服务器,检查了 msi,并且自己在服务器上手动安装它没有问题(通过命令行和 GUI)。然后我从“程序和功能”窗口中卸载了该服务,验证了文件和条目已被删除,再次尝试从构建服务器远程安装它,并再次得到完全相同的错误。该服务只是不会远程安装,因为它认为仍然安装了较新的服务(即使我已经卸载了它),但我可以自己手动完成。

编辑

添加一些日志文本。

Action start 15:47:16: AppSearch.
MSI (s) (B8:F0) [15:47:16:265]: Doing action: FindRelatedProducts
Action ended 15:47:16: AppSearch. Return value 1.
MSI (s) (B8:F0) [15:47:16:267]: Using cached product context: User non-assigned for product: BA4139E4B48F8264ABFF918A7B583A0B
MSI (s) (B8:F0) [15:47:16:267]: Using cached product context: User non-assigned for product: BA4139E4B48F8264ABFF918A7B583A0B
MSI (s) (B8:F0) [15:47:16:267]: Using cached product context: User non-assigned for product: BA4139E4B48F8264ABFF918A7B583A0B
MSI (s) (B8:F0) [15:47:16:267]: Using cached product context: User non-assigned for product: BA4139E4B48F8264ABFF918A7B583A0B
MSI (s) (B8:F0) [15:47:16:267]: Using cached product context: User non-assigned for product: BA4139E4B48F8264ABFF918A7B583A0B
MSI (s) (B8:F0) [15:47:16:267]: Using cached product context: User non-assigned for product: BA4139E4B48F8264ABFF918A7B583A0B
Action start 15:47:16: FindRelatedProducts.
MSI (s) (B8:F0) [15:47:16:267]: PROPERTY CHANGE: Adding NEWERPRODUCTFOUND property. Its value is '{4E9314AB-F84B-4628-BAFF-19A8B785A3B0}'.
MSI (s) (B8:F0) [15:47:16:268]: Doing action: ERRCA_CANCELNEWERVERSION
Action ended 15:47:16: FindRelatedProducts. Return value 1.
MSI (s) (B8:F0) [15:47:16:269]: Note: 1: 2235 2:  3: ExtendedType 4: SELECT `Action`,`Type`,`Source`,`Target`, NULL, `ExtendedType` FROM `CustomAction` WHERE `Action` = 'ERRCA_CANCELNEWERVERSION' 
Action start 15:47:16: ERRCA_CANCELNEWERVERSION.
MSI (s) (B8:F0) [15:47:16:269]: Product: Product.Services -- Unable to install because a newer version of this product is already installed.

Unable to install because a newer version of this product is already installed.
Action ended 15:47:16: ERRCA_CANCELNEWERVERSION. Return value 3.
Action ended 15:47:16: INSTALL. Return value 3.
4

4 回答 4

7

我收到了与@Tom 收到的完全相同的错误:“- 已安装较新版本”

我能够按照以下确切步骤进行修复: 1. 在启用详细日志记录的情况下运行 MSI

msiexec /i "{Path to msi}.msi" /L*V "c:\myLog.log"

2. 打开从上述命令生成的日志文件并复制该行中显示的 GUID

FindRelatedProducts: Found application: {FB0B54D2-9C47-4196-BF0E-B6EEBF754E22}
  1. 使用复制的 GUID,运行以下命令

    msiExec /x {FB0B54D2-9C47-4196-BF0E-B6EEBF754E22}

  2. 此时,旧服务已被卸载,然后我继续使用 MSI 安装服务,没有任何问题。希望这可以帮助。

于 2016-10-12T22:14:58.770 回答
4

MSI (s) (B8:F0) [15:47:16:267]:属性更改:添加 NEWERPRODUCTFOUND 属性。其值为“{4E9314AB-F84B-4628-BAFF-19A8B785A3B0}”。

听起来机器上某处有旧版本的安装,即使它可能不会出现在程序和功能中。我会尝试以下方法,看看它是否能解决您的问题:

  1. 尝试通过命令行卸载msiexec /x {4E9314AB-F84B-4628-BAFF-19A8B785A3B0}

  2. 在注册表中搜索产品代码{4E9314AB-F84B-4628-BAFF-19A8B785A3B0}以查看是否有以前安装的残留物。如果您找到该产品代码,您可以尝试手动删除这些条目(风险自负),看看是否能解决您的问题。

于 2013-02-15T21:18:46.060 回答
1

另一个对我有用的解决方案是:

  1. 在 VS 解决方案中选择您的安装项目,然后按 F4 显示属性窗口
  2. 通过单击此值右侧的按钮更改 ProductCode 和 UpgradeCode 的 GUID。将出现一个新的模式窗口,您只需按“新代码”按钮

请记住,以前的安装将保留在 Windows 注册表中,您应该卸载它们。这仅是在您由于错误(例如使用设置模板)而对不同的 VS 设置具有相同 GUID 的情况下

于 2018-01-02T16:31:54.100 回答
1

如果您在解决方案资源管理器中选择安装文件并按F4,您将获得安装文件的属性。将属性“DetectNewerVersion”设置为 false 并重新安装

祝你好运

于 2019-03-29T12:08:11.497 回答