Loading AI tools
来自维基百科,自由的百科全书
相依性地獄(英語:dependency hell),又稱依賴地獄,是指在操作系統中由於軟件之間的依賴性不能被滿足而引發的問題。
一個軟件包依賴於其它必要的軟件包(且版本要符合要求),使得軟件包系統形成了複雜的依賴關係網絡,並可能引發一系列問題。一些軟件包可能因為依賴性無法滿足,需要安裝大量軟件包;另一方面,一個軟件包的卸載可能引發數量眾多的軟件包無法工作。
目前,GNU/Linux通過高級軟件包管理機制,一定程度上解決了相依性地獄問題。較著名的有Debian陣營的APT[1]和Redhat陣營的Yum,及 Yum 的後繼包管理工具 DNF[2]。
相較「另起爐灶」的做法,現代軟件往往會利用一些已有的組件(如庫、程序、多媒體文件)進行開發。這些組件可能是某個軟件,也可能是專門為其他軟件使用而設計(庫)。程序開發者根據特定版本的組件來設計自己的軟件。這種方式減少了開發的工作量,使得程序比較輕便。但是該軟件要正確運行,必須安裝了指定版本的某些組件。
做一個比喻:你在建造一所房子,而並不生產門窗。由於門洞和窗口的尺寸要和門窗配合,因此你不得不尋找了一家門窗廠商,以他們生產的門窗作為標準,來建造合適的房子。你建造的房屋必須依賴於這家門窗廠商所生產的特定型號的門。
這便是相依性的產生過程。
若只有簡單的相依性,則比較容易解決。如A軟件依賴e、z軟件包,而e、z軟件包沒有依賴,只需要安裝e、z軟件包,再安裝A軟件即可。就如建造商與門窗商的依賴關係,簡單明了。
而當依賴性過多,且具有多級結構,形成錯綜複雜的網絡,依賴性的解析就會變得異常困難,甚至出現無法解析的致命錯誤。
一個軟件包可能依賴於眾多的庫,因此安裝一個軟件包的同時要安裝幾個甚至幾十個庫包。
指從所需軟件包到最底層軟件包之間的層級數過多。這會導致依賴性解析過於複雜,並且容易產生依賴衝突和環形依賴。
即兩個軟件包無法共存的情況。除兩個軟件包包含內容直接衝突外,也可能因為其依賴的低層軟件包互相衝突。因此,兩個看似毫無關聯的軟件包也可能因為依賴性衝突而無法安裝。
即依賴性關係形成一個閉合環路,最終導致:在安裝A軟件包之前,必須要安裝A、B、C、D軟件包,然而這是不可能的。
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.