为什么 Centos 8 中的 yum/dnf 存储库优先级不起作用?

为什么 Centos 8 中的 yum/dnf 存储库优先级不起作用?

我正在尝试安装 MariaDB 提供的 MariaDB RPM,而不是 Centos。由于 DNF 本身支持优先级,因此这应该很简单,只需创建一个类似于以下内容的 .repo 文件:

[MariaDB]
name=The MariaDB 10.4 repository
baseurl=http://yum.mariadb.org/10.4/centos8-amd64
enabled=1
gpgcheck=1
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
priority=1

但是,当我列出可用的软件包时,我确实从新输入的 MariaDB 存储库中获取了软件包,但 priority=1 似乎被忽略了,并且来自 CentOS AppStream 的具有相似(但大小写不同)名称的软件包正在覆盖它。

sudo yum list |grep -i mariadb-server
MariaDB-server-debuginfo.x86_64                      10.4.12-1.el8                                     MariaDB         
mariadb-server.x86_64                                3:10.3.17-1.module_el8.1.0+257+48736ea6           AppStream       
mariadb-server-galera.x86_64                         3:10.3.17-1.module_el8.1.0+257+48736ea6           AppStream       
mariadb-server-utils.x86_64                          3:10.3.17-1.module_el8.1.0+257+48736ea6           AppStream 

但是,如果我在 yum 命令中禁用 AppStream repo,它就会正常工作(忽略 AppStream 中缺少的依赖项):

sudo yum list --disablerepo=AppStream |grep -i mariadb-server
Modular dependency problems:

 Problem 1: conflicting requests
  - nothing provides module(perl:5.26) needed by module perl-DBD-MySQL:4.046:8010020191114030811:073fa5fe-0.x86_64
 Problem 2: conflicting requests
  - nothing provides module(perl:5.26) needed by module perl-DBI:1.641:8010020191113222731:16b3ab4d-0.x86_64
MariaDB-server.x86_64                              10.4.12-1.el8                              MariaDB         
MariaDB-server-debuginfo.x86_64                    10.4.12-1.el8                              MariaDB       

我是不是做错了什么,或者这只是 DNF 中的一个错误,可能是由于 Centos(mariadb-server)和 MariaDB(MariaDB-server)使用的情况不同。

当然可以手动让它工作,但是我想设置 puppet 来自动安装它,但我似乎无法让它工作。

答案1

区分大小写在这里不应该太重要,因为这两个包实际上都提供了mariadb-server功能(相同大小写)。

DNF 希望从 AppStream 安装 MariaDB 的主要原因是它偏爱模块化软件包。这意味着,如果特定软件包(名称)或虚拟提供程序是模块,并且其他存储库中有同名的包,并且它们不是模块的一部分,那么 DNF 将总是想要从模块化存储库安装软件包。

这里有一个有用的命令,可以查找特定包是否是模块的一部分:

sudo dnf module provides mariadb-server

这将查找任何具有mariadb-server包的模块。

在 AppStream repo 中,MariaDB 包与mariadb模块一起。

module_hotfixes=1通过禁用 AppStream,我们给 DNF 蒙上了一层阴影,让它看不到自己喜欢的东西。但更好的方法是通过向感兴趣的存储库添加内容来教会它喜欢非模块化包,例如:

[MariaDB]
name=The MariaDB 10.4 repository
baseurl=http://yum.mariadb.org/10.4/centos8-amd64
enabled=1
gpgcheck=1
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
priority=1
module_hotfixes=1

请注意,优先级配置应保留,因为从技术上讲3:10.3.17(更高Epoch: 3)版本仍然胜过10.4.12Epoch: none,与0:10.4.12)。

相关内容