在linux下的很多軟件都是通過源碼包方式發布的,這樣做對於最終用戶而言,雖然相對於二進制軟件包,配置和編譯起來繁瑣點,但是它的可移植性卻好得多,針對不同的體系結構,軟件開發者往往僅需發布同一份源碼包,不同的最終用戶經過編譯就可以正確運行,這也是非常符合c語言的設計哲學的,一次編寫,到處編譯麼,而常見的二進制包,比如rpm和deb,軟件開發者必須為每種特定的平台定制好專門的軟件包,這個通過rpm文件的後綴名就可以初見端倪,比如ppc,sparc,i386之類,在這裡不做過多的陳述,其實源碼安裝軟件遠沒有很多朋友想象的那麼復雜,下面我在這裡盡可能詳細的做一些陳述,如有謬誤,歡迎朋友們拍磚!
安裝的具體步驟:
___FCKpd___0nbsp;tar zxvf XXXX.tar.gz (or tar jxvf XXXX.tar.bz2)___FCKpd___0nbsp;cd XXXX___FCKpd___0nbsp;./configure___FCKpd___0nbsp;make# make install
___FCKpd___1nbsp;make clean
安裝完成後用來清理臨時文件
# make uninstall
復制代碼
用來卸載軟件
解壓:
最常見源碼包的就兩種(XXXX.tar.gz or XXXX.tar.bz2),其實這些源碼包都是由2個工具壓縮而成的,tar.gz結尾的文件用到的工具是tar和gunzip,而tar.bz2結尾的文件所使用的工具是tar和bzip2,之所以這樣做是因為,tar僅僅能夠打包多個文件但是沒有壓縮的功能,而gz和bz2卻剛好相反,僅能夠壓縮單個文件,這樣我們常見的源碼包實際上是通過tar先將不同的源文件打包,然後再通過gunzip或者bzip2壓縮後發布的,當然這兩個步驟可以通過一條命令實現:
___FCKpd___2nbsp;tar zcvf XXXX.tar.gz XXXX(or tar jcvf XXXX.tar.bz2 XXXX)
復制代碼
解壓的相關命令如下:
___FCKpd___3nbsp;tar zxvf XXXX.tar.gz___FCKpd___3nbsp;tar jxvf XXXX.tar.bz2
復制代碼
./configure:
解壓完成就正式開始安裝了(補充一點,開始configure之前,如有必要,請使用patch工具為源碼打上相應的補丁),首先跳轉到源碼的解壓目錄,眾所周知,開始configure前還是應該仔細閱讀源碼目錄下的README或者INSTALL文件,好多安裝中的注意事項在這裡都有所羅列,configure實際上是一個腳本文件,在當前目錄中鍵入"./configure",shell就會運行當前目錄下的configure腳本,有一點必須說明,在整個configure過程,其實編譯尚未進行,configure僅僅是做編譯相關的准備工作,它主要對您當前的工作平台做一些依賴性檢查,比如編譯器是否安裝,連接器是否存在,如果在檢測的過程沒有任何錯誤,你很幸運,configure腳本會在當前目錄下生成下一步編譯鏈接所要用到的另一個文件Makefile,當然configure支持及其豐富的命令行參數,可以鍵入"./configre --help"獲取具體的信息,最常用的恐怕就是:
___FCKpd___5nbsp;./configure --prefix=/opt/XXX
它用來設置軟件的安裝目錄.
make:
如果configure過程正確完成,那麼在源碼目錄,會生成相應的Makefile文件,Makefile文件簡單來說包括的是一組文件依賴關系以及編譯鏈接的相關步驟,事實上真正的編譯鏈接工作也不是make所做的,make只是一個通用的工具,一般情況下,make會根據Makefile中的規則調用合適的編譯器編譯所有與當前軟件相依賴的源碼,生成所有相關的目標文件,最後再使用鏈接器生成最終的可執行程序:
___FCKpd___6nbsp;make
make install:
當上面兩個步驟正確完成,代表著編譯鏈接過程已經完全結束,最後要做的就是將可執行程序安裝到正確的位置,在這個步驟,普通用戶可能沒有相關目錄的操作權限,臨時切換到root是一個不錯的選擇,"install"只是Makefile文件中的一個標號,"make install"代表著make工具執行Makefile文件中"install"標號下的所有相關操作,如果在configure階段沒有使用"--prefix=/opt/XXX"指定應用程序的安裝目錄,那麼應用程序一般會被默認安裝到/usr/local/bin,如果/usr/local/bin已經存在於您的PATH中,那麼安裝已經基本結束:
#make install
make clean:
make uninstall:
這兩個步驟只是安裝的後續操作,有一點必須注意,"clean"和"uninstall"也是Makefile文件中相應的兩個標號,執行這兩個步驟的時候Makefile文件必要保留,"make clean"用來清除編譯連接過程中的一些臨時文件,"make uninstall"是卸載相關應用程序,與make install類似,make uninstall也需要切換到root執行,不過"uninstall"標號在好多Makefile中都被省略掉了,朋友們完全可以自己在相應的Makefile文件一探究竟.
Why?
在這裡我嘗試著解釋一下上面這些步驟存在的理由,從C語言的角度來說,一個程序從源碼到正確生成相關的可執行文件,下面這些部分必不可少:源文件,編譯器,匯編器,連接器,依賴庫,通過上面幾個步驟,朋友們應該已經知道,真正執行編譯鏈接操作的步驟只有一個(make),那其他步驟存在的理由何在?
有一點是肯定的,我在自己的電腦上使用C語言寫一些自娛自樂的小程序,也沒有用到"configure or make install"之類的命令,頂多自己寫個Makefile管理源文件的依賴關系,可是軟件開發者不同,他必須考慮到軟件的可移植性,他開發的軟件不能僅僅就在他自己的pc上跑吧?不同的平台可能連硬件體系結構都不同,這樣就導致了Makefile的不可移植性,為了解決這個問題,開發者通常使用autoconf之類的工具生成相應的configure腳本,而configure腳本就是用來屏蔽相應的平台差異,從而正確生成Makefile文件,然後make再根據configure的勞動成果(Makefile)完成編譯鏈接工作.
至於"install or clean or uninstall",也只是對應著Makefile文件中不同的規則,關於Makefile的詳細信息,朋友們可以自行查閱相關的文檔.
一個例子
下面是我在自己的pc機上源碼安裝tar工具的過程,權當做是上面這些步驟的一個具體事例吧:
[root@localhost ~]# head -n 1 /etc/issueCentOS release 5.4 (Final)[root@localhost ~]# uname -srLinux 2.6.18-164.el5[root@localhost ~]# gcc --versiongcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46)Copyright (C) 2006 Free Software Foundation, Inc.
這個是我的系統信息。
[root@localhost tools]# pwd/root/tools[root@localhost tools]# lstar-1.23.tar.bz2[root@localhost tools]# tar jxvf tar-1.23.tar.bz2......[root@localhost tools]# lstar-1.23 tar-1.23.tar.bz2[root@localhost tools]# cd tar-1.23[root@localhost tar-1.23]# lsABOUT-NLS build-aux configure gnu Makefile.am po srcacinclude.m4 ChangeLog configure.ac INSTALL Makefile.in README testsaclocal.m4 ChangeLog.1 COPYING lib Make.rules rmt THANKSAUTHORS config.h.in doc m4 NEWS scripts TODO
解壓原文件包,可以發現其中包括了configure腳本和README文件。
[root@localhost tar-1.23]# mkdir -v ~/tarmkdir: 已創建目錄 “/root/tar”[root@localhost tar-1.23]# ./configure --prefix=/root/tar......[root@localhost tar-1.23]# echo $?
建立軟件安裝目錄,並configure,檢查configure返回結果,為0代表運行成功.
[root@localhost tar-1.23]# ls -FABOUT-NLS ChangeLog.1 configure.ac m4/ po/ tests/acinclude.m4 config.h COPYING Makefile README THANKSaclocal.m4 config.h.in doc/ Makefile.am rmt/ TODOAUTHORS config.log gnu/ Makefile.in scripts/build-aux/ config.status* INSTALL Make.rules src/ChangeLog configure* lib/ NEWS stamp-h1
復制代碼
可以看到Makefile文件已經被成功建立.
[root@localhost tar-1.23]# less Makefile | grep install: || { echo "ERROR: files left after uninstall:" ; install: install-recursiveuninstall: uninstall-recursive
在建立的Makefile中存在install和uninstall標號
[root@localhost tar-1.23]#make......[root@localhost tar-1.23]#echo &?
0
make成功
[root@localhost tar-1.23]#make install......[root@localhost tar-1.23]# ls /root/tarbin libexec sbin share[root@localhost tar]# cd /root/tar/bin[root@localhost bin]# lstar[root@localhost bin]# ./tar --help......[root@localhost tar-1.23]#echo &?
0
安裝並簡單測試成功。