可以在 RPM 规范文件中要求“这个或那个”包吗?

可以在 RPM 规范文件中要求“这个或那个”包吗?

是否有人知道如何(或是否可以)在规范文件中指定替代要求或一组要求,而不是单一要求?

例如,假设有两个可用的包,分别命名为foo-barbar-foo。我的包需要其中一个,但不需要两个,而且我不在乎哪个存在。在运行时我会使用可用的那个。

因此,我希望可以这样有效地表达:

Requires: foo-bar OR bar-foo

据我所知这是不可能的,但我认为这里有些人比我更了解 RPM,所以也许有办法做到。

bar-foo更新:我只控制的包装,而不是的包装foo-bar,因此让两者都提供虚拟包是行不通的。

更新:我真正需要的东西本身就是虚拟包在每个软件包中。假设foo-bar provides eagle' andbar-foo 提供了 beagle and my package works with either (or both); but other packages require eithereagle orbeagle orfoo-bar orbar-foo`,则目标系统可以安装其中一个或两个。

我目前倾向于使用%pre类似以下的脚本来解决这个问题:

rpm -q eagle || rpm -q beagle || echo "need eagle or beagle" && /bin/false

虽然我非常确定这样做是可行的,但这似乎是对 RPM 依赖性跟踪的粗暴规避。例如,当您询问whatrequires foo-bar或时,您永远不会看到我的软件包whatrequires beagle

更新:再想想,要求人们foo-bar在他们可能不会安装的地方安装的痛苦比绕过 RPM 依赖管理的痛苦要小,至少对我来说是这样。因此,除非有人想出一种方法来正确地要求“这个或那个”(我认为这通常是 RPM 的一个很棒的功能),否则我打算要求仅有的 foo-bar然后,在运行时,如果bar-foo可用,我将根据我需要的标准在它们之间进行选择。

更新:另一个想法,这也会欺骗 RPM,但可能会让事情进入正确的状态。也许我可以%post直接摆弄 RPM 的数据库。这样%pre可以保护我免受无效安装的影响,并%post会追溯性地告诉 RPM 我需要其中一个foo-barbar-foo两个,具体取决于我安装时的内容。

感谢您的建议!

答案1

从 RPM 4.13 开始这已经成为可能。

https://rpm-software-management.github.io/rpm/manual/boolean_dependencies.html

它可以简单到如下:Requires: (pkgA >= 3.2 or pkgB)

答案2

这种行为已经被多个软件包实现,例如邮件传输代理。那些虚拟包为您的系统提供一种方法来了解其所需的功能是否已经由其他程序提供。

看看虚拟包rpm.org 中的示例可以帮助您。

答案3

两种可能性:

foo-bar如果您使用的和部分bar-foo是通用文件,您可以Require /path/to/file(我思考所以;我的测试是有限的)。

你的情况类似于可选依赖项。处理它们的方法是有一个X-common包,然后有一个X-foo-bar需要的包foo-bar和一个X-bar-foo需要的包bar-foo

答案4

自动化系统(依赖管理或使用 RPM 的机器)中的非确定性是一件非常糟糕的事情。您希望它在这样或那样的情况下失败,因为失败仍然不如意外结果那么糟糕。

要解决这个问题,也许可以让你控制的包提供不可变包也提供的主要标记,而你的其他软件又依赖这些标记;然后让你的包淘汰不可变包。特别是如果它已经到位,你可能会让它胜过其他安装。

打包和正确的依赖关系以及安装操作是一项棘手的工作。目标 - 可靠、可重复、可审计的安装 - 非常有价值,您可能会意识到正确完成安装的好处。

依赖地狱是自己造成的。没有例外

相关内容