在Linux上安裝程序通常與在Windows上傳統(tǒng)的安裝軟件方式有所不同。你可以使用預構建的軟件包,或者自己編譯程序。如今,預構建軟件包通常是默認的選擇,但在某些情況下,你可能想考慮從源代碼進行編譯。
什么是二進制包?
在Linux上安裝程序通常與在Windows上傳統(tǒng)的安裝軟件方式有所不同。而不是從供應商的網站上下載安裝程序,文件來自于一個程序倉庫,通常根據你的Linux發(fā)行版進行定制。你可以使用Linux軟件包管理器或應用商店訪問這個倉庫。
這些倉庫中的程序由多個文件組成,并以一個歸檔格式進行打包,以便于訪問和分發(fā)。例如,Debian使用DEB格式存儲和分發(fā)程序。這些打包文件被稱為二進制包。
如何閱讀二進制代碼
你需要一個特殊的程序來提取這些文件并將其安裝到計算機上,通常是你的軟件包管理器或應用商店。這些工具還具有其他有用的功能,例如跟蹤已安裝的文件和管理軟件更新。
較新的軟件包格式,如Flatpak和Snap,適用于不同版本的Linux,但它們仍然由預編譯的二進制程序組成。兩者都需要圖形化的應用商店或基于命令行的軟件包管理器進行安裝。
什么是源代碼?
所有軟件都由稱為源代碼的文本行組成,用特定的編程語言編寫,例如C或C++。通常情況下,你不能只將這些源代碼打包成一個存檔文件并稱之為軟件包。這些行需要被轉換為計算機可以理解和執(zhí)行的語言。
這個過程被稱為編譯,最終的結果是創(chuàng)建出計算機可以運行的二進制文件。軟件包和軟件的區(qū)別在于,軟件的二進制文件與其他文件(如配置文件)一起存儲在一個包中。
什么是“從源代碼安裝”?
從源代碼安裝程序意味著不使用軟件包管理器進行安裝。你需要編譯源代碼,并將二進制文件復制到計算機上。
大多數(shù)情況下,你可以從諸如GitHub、GitLab或Bitbucket等托管服務上下載項目的源代碼。較大的程序甚至可能在個人網站上托管源代碼。該代碼通常以一個歸檔格式(也稱為源代碼包)進行壓縮。
一組特殊的工具幫助自動化構建過程。在Linux桌面上,通常以一個名為make的命令行程序的形式存在。用不同語言編寫的源代碼需要特定的編譯器和命令將其轉換為二進制文件。make程序自動化了這個過程。
為了使這個自動化工作起來,程序提供了一個名為Makefile的文件,告訴make應該做什么和如何編譯。如今,Makefile通常由特殊的軟件(如CMake)自動生成。這就是你需要介入的地方。從這里開始,你可以指定想要編譯到軟件中的具體功能。
從源代碼構建的示例
例如,下面的命令使用CMake為Calligra辦公套件生成一個配置文件。創(chuàng)建的文件告訴make程序只編譯Calligra的Writer組件。
cmake -DPRODUCTSET=WORDS -DCMAKE_INSTALL_PREFIX=$HOME/kde/inst5 $HOME/kde/src/calligra
完成這一步驟后,用戶只需運行make工具來編譯并將結果復制到他們的計算機上。操作步驟如下:
make make install
雖然這是編譯程序的一般模式,但還有許多其他安裝源代碼包的方法。例如,Gentoo Linux內置了一種處理源代碼包的方法,使得該過程更快捷、更簡便。但是構建二進制包需要比上述命令更多的步驟。
使用二進制包的好處
如果你使用Linux,很可能有人預編譯了你已安裝的軟件。這比使用源代碼包更為常見。但是為什么會這樣呢?
1、二進制版本更易管理
二進制包不僅包含已編譯的安裝文件,還存儲了其他信息,使得你的包管理器能夠輕松跟蹤所有程序。例如,DEB文件(Debian及其衍生版的包格式)還包含重要信息,如程序運行所需的其他軟件以及當前版本。
這使得安裝包變得更加簡單,因為你不需要擔心需要哪些其他文件才能成功運行程序。你的包管理器可以從包本身讀取這些信息,并自動下載所有必要的依賴項。
而當從源代碼安裝程序時,除非將代碼編譯為獨立的二進制包,否則你將需要負責管理該軟件。你需要記住你需要哪些其他程序來使其工作,并自行安裝它們。
2、二進制版本具有更好的穩(wěn)定性
負責維護包管理器倉庫的人員往往會對二進制文件進行測試,并盡力修復出現(xiàn)的問題。這可能導致提高穩(wěn)定性,因為包維護人員可能會發(fā)現(xiàn)安裝源代碼的人可能忽視的問題。
此外,包通常必須遵守一套嚴格的規(guī)則,以確保它們能在你的系統(tǒng)上運行。例如,Debian和Ubuntu都有一個政策手冊,許多其他Linux發(fā)行版也有類似的手冊。
有些程序還依賴于不同版本的同一軟件依賴項來運行。軟件包倉庫會盡力解決這些沖突,以免給你帶來麻煩。
編譯源代碼包的好處
從源代碼安裝程序并不是每個人都需要做的事情,因為如果堅持使用二進制包,通常更容易維護你的計算機。盡管如此,使用這種稍微復雜一些的方式安裝程序仍然有一些優(yōu)勢。
1、源代碼提供最新軟件
使程序更加可靠的一個缺點是需要時間來改進和修復。有時候可能有可用的二進制文件,但源代碼會稍后提供。對于希望擁有最新和最好的軟件的人來說,他們可能愿意在交換較新軟件的同時稍微犧牲一些穩(wěn)定性。
雖然有一些Linux操作系統(tǒng)可以滿足這種需求而無需編譯程序,但它們也有一些缺點。例如,那些不經常發(fā)布固定軟件包版本的軟件在存儲庫中難以保持最新。相比之下,從源代碼安裝則不受這些限制。
這是因為二進制包通常是根據官方發(fā)布的程序版本制作的。因此,這些版本之間的更改通常不會被考慮在內。通過從源代碼編譯自己的軟件,你可以立即從這些更改中受益。
也有可能你的Linux操作系統(tǒng)沒有預先為你準備好你想要的軟件。過去,這將使得從源代碼安裝是唯一的選擇。通用的軟件包格式已經改變了這一點。Flatpak和Snap軟件包通常也比系統(tǒng)存儲庫更快地接收更新。但仍然有時候編譯是獲得所需軟件的唯一途徑。
2、你可以自己選擇功能
FFmpeg的功能 使用源代碼包的另一個好處是你可以更加掌控你安裝的程序。當從二進制軟件庫安裝時,你在自定義軟件包方面受到限制。
以FFmpeg為例,它是一個基于命令行的音視頻轉換工具。默認情況下,它帶有大量的功能,其中一些你可能從未使用過。例如,F(xiàn)Fmpeg支持JACK音頻,盡管這個軟件通常只在生產環(huán)境中使用。
通過編譯FFmpeg,你可以移除你不需要的功能,使其更加輕巧并符合你的需求。同樣的原理也適用于其他龐大的程序。
當資源有限時,移除功能可以有效減輕負荷。難怪許多低端計算機上都使用基于Gentoo Linux的ChromeOS。Gentoo是基于源代碼的,它編譯了許多軟件,潛在地使這些系統(tǒng)運行得更加輕巧。
為什么不同時使用二進制和源代碼包呢?
雖然你可能不會每天都想編譯軟件包,但這是一種有用的方法。盡管如此,隨著從Snap Store和Flathub等網站提供的新的通用軟件包格式,你更不太可能需要從源代碼構建以獲得最新的軟件。
最近很多小伙伴找我要一些程序員必備資料,于是我翻出了壓箱底的寶藏,免費分享給大家!
審核編輯:湯梓紅
評論
查看更多