為什麼在 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 儲存庫中獲取包,但優先級 = 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 儲存庫,它會正常工作(忽略 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 自動安裝它,我似乎無法正常工作。
區分大小寫在這裡不應該那麼重要,因為這兩個包實際上都提供了
mariadb-server
功能(相同的大小寫)。DNF 想要從 AppStream 安裝 MariaDB 的主要原因是它偏愛模組化包。這意味著,如果特定包(名稱)或虛擬提供是模組的一部分,並且其他儲存庫中存在具有相同名稱的包並且它們不是模組的一部分,那麼 DNF 將始終希望從模組化儲存庫。
這裡有一個有用的命令,用於查找特定包是否是模組的一部分:
sudo dnf module provides mariadb-server
這會找到任何有
mariadb-server
包的模組。在 AppStream 儲存庫中,MariaDB 包隨
mariadb
模組一起提供。通過禁用 AppStream,我們對 DNF 進行了盲注,因此它看不到牠喜歡什麼。
module_hotfixes=1
但更好的方法是通過添加到感興趣的儲存庫來教牠喜歡非模組化包,例如:[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.12
(Epoch: none
,與 相同0:10.4.12
)。