相依性地獄

相依性地獄(英語:Dependency hell),是指在作業系統中由於軟體之間的依賴性不能被滿足而引發的問題。

基本介紹

  • 中文名:相依性地獄
  • 外文名:Dependency hell
簡介,問題由來,問題類型,依賴過多,多重依賴,依賴衝突,依賴循環,

簡介

相依性地獄(英語:Dependency hell),是指在作業系統中由於軟體之間的依賴性不能被滿足而引發的問題。
一個軟體包依賴於其它必要的軟體包(且版本要符合要求),使得軟體包系統形成了複雜的依賴關係網路,並可能引發一系列問題。一些軟體包可能因為依賴性無法滿足,需要安裝大量軟體包;另一方面,一個軟體包的卸載可能引發數量眾多的軟體包無法工作。
目前,GNU/Linux通過高級軟體包管理機制,一定程度上解決了相依性地獄問題。較著名的有Debian陣營的APTRedhat陣營的Yum

問題由來

相較“另起爐灶”的做法,現代軟體往往會利用一些已有的組件(如庫、程式、多媒體檔案)進行開發。這些組件可能是某個軟體,也可能是專門為其他軟體使用而設計()。程式開發者根據特定版本的組件來設計自己的軟體。這種方式減少了開發的工作量,使得程式比較輕便。但是該軟體要正確運行,必須安裝了指定版本的某些組件。
做一個比喻:你在建造一所房子,而並不生產門窗。由於門洞和視窗的尺寸要和門窗配合,因此你不得不尋找了一家門窗廠商,以他們生產的門窗作為標準,來建造合適的房子。你建造的房屋必須依賴於這家門窗廠商所生產的特定型號的門。
這便是相依性的產生過程。
若只有簡單的相依性,則比較容易解決。如A軟體依賴e、z軟體包,而e、z軟體包沒有依賴,只需要安裝e、z軟體包,再安裝A軟體即可。就如建造商與門窗商的依賴關係,簡單明了。
而當依賴性過多,且具有多級結構,形成錯綜複雜的網路,依賴性的解析就會變得異常困難,甚至出現無法解析的致命錯誤。
由於軟體包更新迅速,且互相不同步,依賴性所要求的版本條件可能很快便不存在。
當多個軟體包同時依賴於一個軟體包,但所要求的版本不同。如A軟體包依賴gcc-4.6及以上而B軟體依賴gcc-4.5,那么就會產生相依性衝突。這種情況下,兩個軟體包A、B無法同時滿足依賴性,無法同時安裝或運行。
當一個軟體包依賴多個軟體包,解析依賴性的難度會加大。如A軟體包依賴40個軟體包,而這40個軟體包每個又都有自身的依賴關係,依賴關係深達 3-5層。這樣的計算,靠人力有時是難以完成的,必須藉助軟體包管理器進行自動解析。同時,安裝組件的數量也會由於依賴性過多而增長。
當兩個軟體包不共存的時候,可能會對整個體系造成巨大衝擊。若是兩個底層軟體包,則影響會更大。由依賴關係形成的網路會斷裂為不共存的兩部分。在建立軟體包體系的過程中,要儘量避免這種情況發生,尤其是底層軟體包的不共存問題。
在特殊情況下還會產生不可解的依賴關係,如依賴死循環。

問題類型

依賴過多

一個軟體包可能依賴於眾多的庫,因此安裝一個軟體包的同時要安裝幾個甚至幾十個庫包。

多重依賴

指從所需軟體包到最底層軟體包之間的層級數過多。這會導致依賴性解析過於複雜,並且容易產生依賴衝突和環形依賴。

依賴衝突

即兩個軟體包無法共存的情況。除兩個軟體包包含內容直接衝突外,也可能因為其依賴的低層軟體包互相衝突。因此,兩個看似毫無關聯的軟體包也可能因為依賴性衝突而無法安裝。

依賴循環

即依賴性關係形成一個閉合環路,最終導致:在安裝A軟體包之前,必須要安裝A、B、C、D軟體包,然而這是不可能的。

相關詞條

熱門詞條

聯絡我們