DNF 和 Yum 的區別,為什麼 Yum 會被 DNF 取代?

2020-04-29 09:40:00

由於 Yum 中許多長期存在的問題仍未得到解決,因此 Yum 包管理器已被 DNF 包管理器取代。這些問題包括效能差、記憶體占用過多、依賴解析速度變慢等。

DNF 使用 libsolv 進行依賴解析,由 SUSE 開發和維護,旨在提高效能。

Yum 主要是用 Python 編寫的,它有自己的應對依賴解析的方法。它的 API 沒有完整的文件,它的擴充套件系統只允許 Python 外掛。

Yum 是 RPM 的前端工具,它管理依賴關係和資源庫,然後使用 RPM 來安裝、下載和刪除包。

為什麼他們要建立一個新的工具,而不是修復現有的問題呢?

Ales Kozamblak 解釋說,這個修復在技術上是不可行的,而且 Yum 團隊還沒有準備好立即接受修改。

另外,最大的挑戰是,Yum 有 56000 行程式碼,但 DNF 只有 29000 行程式碼。

所以除了分叉,沒有辦法解決。

不過 Yum 的執行情況還算可以。

編號DNF(Dandified YUM)YUM(Yellowdog Updater, Modified)
1DNF 使用 libsolv 來解析依賴關係,由 SUSE 開發和維護YUM 使用公開的 API 來解析依賴關係
2API 有完整的文件API 沒有完整的文件
3由 C、C++、Python 編寫的只用 Python 編寫
4DNF 目前在 Fedora、RHEL 8、CentOS 8、OEL 8 和 Mageia 6/7 中使用YUM 目前在 RHEL 6/7、CentOS 6/7、OEL 6/7 中使用
5DNF 支援各種擴充套件Yum 只支援基於 Python 的擴充套件
6API 有良好的文件,因此很容易建立新的功能因為 API 沒有正確的文件化,所以建立新功能非常困難
7DNF 在同步儲存庫的後設資料時,使用的記憶體較少在同步儲存庫的後設資料時,YUM 使用了過多的記憶體
8DNF 使用滿足性演算法來解決依賴關係解析(它是用字典的方法來儲存和檢索包和依賴資訊)由於使用公開 API 的原因,Yum 依賴性解析變得遲鈍
9從記憶體使用量和版本庫後設資料的依賴性解析來看,效能都不錯總的來說,在很多因素的影響下,表現不佳
10DNF 更新:在 DNF 更新過程中,如果包中包含不相關的依賴,則不會更新YUM 將在沒有驗證的情況下更新軟體包
11如果啟用的儲存庫沒有響應,DNF 將跳過它,並繼續使用可用的儲存庫處理事務如果有儲存庫不可用,YUM 會立即停止
12dnf updatednf upgrade 是等價的在 Yum 中則不同
13安裝包的依賴關係不更新Yum 為這種行為提供了一個選項
14清理刪除的包:當刪除一個包時,DNF 會自動刪除任何沒有被使用者明確安裝的依賴包Yum 不會這樣做
15儲存庫快取更新計劃:預設情況下,系統啟動後 10 分鐘後,DNF 每小時會對設定的儲存庫檢查一次更新。這個動作由系統定時器單元 dnf-makecache.timer 控制Yum 也會這樣做
16核心包不受 DNF 保護。不像 Yum,你可以刪除所有的核心包,包括執行中的核心包Yum 不允許你刪除執行中的核心
17libsolv:用於解包和讀取資源庫。hawkey: 為 libsolv 提供簡化的 C 和 Python API 庫。librepo: 提供 C 和 Python(類似 libcURL)API 的庫,用於下載 Linux 儲存庫後設資料和軟體包。libcomps: 是 yum.comps 庫的替代品。它是用純 C 語言編寫的庫,有 Python 2 和 Python 3 的系結。Yum 不使用單獨的庫來執行這些功能
18DNF 包含 29000 行程式碼Yum 包含 56000 行程式碼
19DNF 由 Ales Kozumplik 開發YUM 由 Zdenek Pavlas、Jan Silhan 和團隊成員開發