Centos

為什麼在 Centos 8 的 yum/dnf 中儲存庫優先級不起作用?

  • May 12, 2020

我正在嘗試安裝 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.12Epoch: none,與 相同0:10.4.12)。

引用自:https://serverfault.com/questions/1016837