Linux環境下的軟件安裝,並非一件容易的事情;若是經過源代碼編譯後在安裝,固然事情就更爲複雜一些;如今安裝各類軟件的教程都很是廣泛;但萬變不離其中,對基礎知識的紮實掌握,安裝各類軟件的問題就迎刃而解了。Configure腳本配置工具就是基礎之一,它是autoconf的工具的基本應用。 node
'configure'腳本有大量的命令行選項.對不一樣的軟件包來講,這些選項可能會有變化,可是許多基本的選項是不會改變的.帶上'--help'選項執行'configure'腳本能夠看到可用的全部選項.儘管許多選項是不多用到的,可是當你爲了特殊的需求而configure一個包時,知道他們的存在是頗有益處的.下面對每個選項進行簡略的介紹: linux
--cache-file=FILE,'configure'會在你的系統上測試存在的特性(或者bug!).爲了加速隨後進行的配置,測試的結果會存儲在一個cache file裏.當configure一個每一個子樹裏都有'configure'腳本的複雜的源碼樹時,一個很好的cache file的存在會有很大幫助. 數據庫
--help輸出幫助信息.即便是有經驗的用戶也偶爾須要使用使用'--help'選項,由於一個複雜的項目會包含附加的選項.例如,GCC包裏的'configure'腳本就包含了容許你控制是否生成和在GCC中使用GNU彙編器的選項. 緩存
--no-create,'configure'中的一個主要函數會製做輸出文件.此選項阻止'configure'生成這個文件.你能夠認爲這是一種演習(dry run),儘管緩存(cache)仍然被改寫. app
--quiet,--silent,當'configure'進行他的測試時,會輸出簡要的信息來告訴用戶正在做什麼.這樣做是由於'configure'可能會比較慢,沒有這種輸出的話用戶將會被扔在一旁疑惑正在發生什麼.使用這兩個選項中的任何一個都會把你扔到一旁.(譯註:這兩句話比較有意思,原文是這樣的:If there was no such output, the user would be left wondering what is happening. By using this option, you too can be left wondering!) 函數
--version,打印用來產生'configure'腳本的Autoconf的版本號. 工具
--prefix=PEWFIX,'--prefix'是最經常使用的選項.製做出的'Makefile'會查看隨此選項傳遞的參數,當一個包在安裝時能夠完全的從新安置他的結構獨立部分. 舉一個例子,當安裝一個包,例如說Emacs,下面的命令將會使Emacs Lisp file被安裝到"/opt/gnu/share":
$ ./configure --prefix=/opt/gnu 性能
--exec-prefix=EPREFIX,與'--prefix'選項相似,可是他是用來設置結構倚賴的文件的安裝位置.編譯好的'emacs'二進制文件就是這樣一個問件.若是沒有設置這個選項的話,默認使用的選項值將被設爲和'--prefix'選項值同樣. 測試
--bindir=DIR,指定二進制文件的安裝位置.這裏的二進制文件定義爲能夠被用戶直接執行的程序. ui
--sbindir=DIR,指定超級二進制文件的安裝位置.這是一些一般只能由超級用戶執行的程序.
--libexecdir=DIR,指定可執行支持文件的安裝位置.與二進制文件相反,這些文件歷來不直接由用戶執行,可是能夠被上面提到的二進制文件所執行.
--datadir=DIR,指定通用數據文件的安裝位置.
--sysconfdir=DIR,指定在單個機器上使用的只讀數據的安裝位置.
--sharedstatedir=DIR,指定能夠在多個機器上共享的可寫數據的安裝位置.
--localstatedir=DIR,指定只能單機使用的可寫數據的安裝位置.
--libdir=DIR,指定庫文件的安裝位置.
--includedir=DIR,指定C頭文件的安裝位置.其餘語言如C++的頭文件也可使用此選項.
--oldincludedir=DIR,指定爲除GCC外編譯器安裝的C頭文件的安裝位置.
--infodir=DIR,指定Info格式文檔的安裝位置.Info是被GNU工程所使用的文檔格式.
--mandir=DIR,指定手冊頁的安裝位置.
--srcdir=DIR,這個選項對安裝沒有做用.他會告訴'configure'源碼的位置.通常來講不用指定此選項,由於'configure'腳本通常和源碼文件在同一個目錄下.
--program-prefix=PREFIX,指定將被加到所安裝程序的名字上的前綴.例如,使用'--program-prefix=g'來configure一個名爲'tar'的程序將會使安裝的程序被命名爲'gtar'.當和其餘的安裝選項一塊兒使用時,這個選項只有當他被`Makefile.in'文件使用時纔會工做.
--program-suffix=SUFFIX,指定將被加到所安裝程序的名字上的後綴.
--program-transform-name=PROGRAM,這裏的PROGRAM是一個sed腳本.當一個程序被安裝時,他的名字將通過`sed -e PROGRAM'來產生安裝的名字.
--build=BUILD,指定軟件包安裝的系統平臺.若是沒有指定,默認值將是'--host'選項的值.
--host=HOST,指定軟件運行的系統平臺.若是沒有指定,將會運行`config.guess'來檢測.
--target=GARGET,指定軟件面向(target to)的系統平臺.這主要在程序語言工具如編譯器和彙編器上下文中起做用.若是沒有指定,默認將使用'--host'選項的值.
--disable-FEATURE,一些軟件包能夠選擇這個選項來提供爲大型選項的編譯時配置,例如使用Kerberos認證系統或者一個實驗性的編譯器最優配置.若是默認是提供這些特性,可使用'--disable-FEATURE'來禁用它,這裏'FEATURE'是特性的名字.
例如:$ ./configure --disable-gui
-enable-FEATURE[=ARG],相反的,一些軟件包可能提供了一些默認被禁止的特性,可使用'--enable-FEATURE'來起用它.這裏'FEATURE'是特性的名字.一個特性可能會接受一個可選的參數.例如:$ ./configure --enable-buffers=128
`--enable-FEATURE=no'與上面提到的'--disable-FEATURE'是同義的.
--with-PACKAGE[=ARG],在自由軟件社區裏,有使用已有軟件包和庫的優秀傳統.當用'configure'來配置一個源碼樹時,能夠提供其餘已經安裝的軟件包的信息.例如,倚賴於Tcl和Tk的BLT器件工具包.要配置BLT,可能須要給'configure'提供一些關於咱們把Tcl和Tk裝的何處的信息:$ ./configure --with-tcl=/usr/local --with-tk=/usr/local
'--with-PACKAGE=no'與下面將提到的'--without-PACKAGE'是同義的.
--without-PACKAGE,有時候你可能不想讓你的軟件包與系統已有的軟件包交互.例如,你可能不想讓你的新編譯器使用GNU ld.經過使用這個選項能夠作到這一點:
$ ./configure --without-gnu-ld
--x-includes=DIR,這個選項是'--with-PACKAGE'選項的一個特例.在Autoconf最初被開發出來時,流行使用'configure'來做爲Imake的一個變通方法來製做運行於X的軟件.'--x-includes'選項提供了向'configure'腳本指明包含X11頭文件的目錄的方法.
--x-libraries=DIR,相似的,'--x-libraries'選項提供了向'configure'腳本指明包含X11庫的目錄的方法.
在源碼樹中運行'configure'是沒必要要的同時也是很差的.一個由'configure'產生的良好的'Makefile'能夠構築源碼屬於另外一棵樹的軟件包.在一個獨立於源碼的樹中構築派生的文件的好處是很明顯的:派生的文件,如目標文件,會凌亂的散佈於源碼樹.這也使在另外一個不一樣的系統或用不一樣的配置選項構築一樣的目標文件很是困難.建議使用三棵樹:一棵源碼樹(source tree),一棵構築樹(build tree),一棵安裝樹(install tree).這裏有一個很接近的例子,是使用這種方法來構築GNU malloc包:
$ gtar zxf mmalloc-1.0.tar.gz
$ mkdir build && cd build
$ ../mmalloc-1.0/configure
creating cache ./config.cache
checking for gcc... gcc
checking whether the C compiler (gcc ) works... yes
checking whether the C compiler (gcc ) is a cross-compiler... no
checking whether we are using GNU C... yes
checking whether gcc accepts -g... yes
checking for a BSD compatible install... /usr/bin/install –c
checking host system type... i586-pc-linux-gnu
checking build system type... i586-pc-linux-gnu
checking for ar... ar
checking for ranlib... ranlib
checking how to run the C preprocessor... gcc –E
checking for unistd.h... yes
checking for getpagesize... yes
checking for working mmap... yes
checking for limits.h... yes
checking for stddef.h... yes
updating cache ../config.cache
creating ./config.status
這樣這棵構築樹就被配置了,下面能夠繼續構築和安裝這個包到默認的位置'/usr/local':
$ make all && make install
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1440383
一個軟件包經過編譯源代碼安裝後,如何徹底的卸載?
若是原先的source還在的話,不少source的Makefile都有寫uninstall規則,直接在Souce裏make uninstall就可行,不過碰到無良做者沒寫的,那一句一句看Makefile裏install部分他都幹了些什麼,而後挨個刪除。
若是source沒了.....那就一邊鬱悶吧
到目前爲止, 我裝的均可以make uninstall.......
(由於老是不當心裝錯地方, 結果就make uninstall&&make clean,而後從新configure......) |
Linux軟件的安裝和卸載一直是困擾許多新用戶的難題。在Windows中,咱們可使用軟件自帶的安裝卸載程序或在控制面板中的"添加/刪除程序"來實現。與其相相似,在Linux下有一個功能強大的軟件安裝卸載工具,名爲RPM。它能夠用來創建、安裝、查詢、更新、卸載軟件。該工具是在命令行下使用的。在Shell的提示符後輸入rpm,就可得到該命令的幫助信息。 軟件的安裝 Linux下軟件的安裝主要有兩種不一樣的形式。第一種安裝文件名爲xxx.tar.gz;另外一種安裝文件名爲xxx.i386.rpm。以第一種方式發行的軟件多爲以源碼形式發送的;第二種方式則是直接以二進制形式發送的。 對於第一種,安裝方法以下: 1 .首先,將安裝文件拷貝至你的目錄中。例如,若是你是以root身份登陸上的,就將軟件拷貝至/root中。 #cp xxx.tar.gz /root 2 .因爲該文件是被壓縮並打包的,應對其解壓縮。命令爲: 3. 執行該命令後,安裝文件按路徑,解壓縮在當前目錄下。用ls命令能夠看到解壓縮後的文件。一般在解壓縮後產生的文件中,有"Install"的文件。該文件爲純文本文件,詳細講述了該軟件包的安裝方法。 4.執行解壓縮後產生的一個名爲configure的可執行腳本程序。它是用於檢查系統是否有編譯時所需的庫,以及庫的版本是否知足編譯的須要等安裝所須要的系統信息。爲隨後的編譯工做作準備。命令爲: #./configure 若是您想把軟件安裝到指定目錄,應該用#./configure --prefix=/您本身指定的目錄,好比我想把一個mlterm安裝到/opt/mlterm目錄中,應該以下輸入 #./configure --prefix=/opt/mlterm 5.檢查經過後,將生成用於編譯的MakeFile文件。此時,能夠開始進行編譯了。編譯的過程視軟件的規模和計算機性能的不一樣,所耗費的時間也不一樣。命令爲: #make。 6.成功編譯後,鍵入以下的命令開始安裝: #make install 7.安裝完畢,應清除編譯過程當中產生的臨時文件和配置過程當中產生的文件。鍵入以下命令: #make distclean 至此,軟件的安裝結束。 對於第二種,其安裝方法要簡單得多。 同第一種方式同樣,將安裝文件拷貝至你的目錄中。而後使用rpm來安裝該文件。命令以下: rpm將自動將安裝文件解包,並將軟件安裝到缺省的目錄下。並將軟件的安裝信息註冊到rpm的數據庫中。參數i的做用是使rpm進入安裝模式。 軟件的卸載 1.軟件的卸載主要是使用rpm來進行的。卸載軟件首先要知道軟件包在系統中註冊的名稱。鍵入命令: #rpm -q –a 便可查詢到當前系統中安裝的全部的軟件包。 2. 肯定了要卸載的軟件的名稱,就能夠開始實際卸載該軟件了。鍵入命令: #rpm -e [package name] 便可卸載軟件。參數e的做用是使rpm進入卸載模式。對名爲[package name]的軟件包進行卸載。因爲系統中各個軟件包之間相互有依賴關係。若是因存在依賴關係而不能卸載,rpm將給予提示並中止卸載。你可使用以下的命令來忽略依賴關係,直接開始卸載: #rpm -e [package name] –nodeps 忽略依賴關係的卸載可能會致使系統中其它的一些軟件沒法使用 若是想知道rpm包安裝到哪裏了呢? 應該用 #rpm -ql [package name] 3.如何卸載用源碼包安裝的軟件? 最好是看README和INSTALL ;通常的狀況下都有說,但大多軟件沒有提供源碼包的卸載方法;咱們能夠找到軟件的安裝點刪除。主要看你把它安裝在哪了。好比: 若是安裝軟件時,指定個目錄。這個問題也不會難; 好比用源碼包安裝gaim 的 #./configure --prefix=/opt/gaim #make #make install 若是安裝mlterm #./configure --prefix=/opt/mlterm #make #make install 把源碼包安裝的軟件,都指定安裝在 /opt目錄中,這樣不就知道了?? 若是刪除,就刪除相應的軟件目錄; 有些軟件要在解壓安裝目錄中執行 make uninstall ,這樣就卸載掉了 |