Linux ./configure --prefix命令

源碼的安裝一般由3個步驟組成:配置(configure)、編譯(make)、安裝(make install),具體的安裝方法一般作者都會給出文檔,這裏主要討論配置(configure)。Configure是一個可執行腳本,它有很多選項,使用命令./configure –help輸出詳細的選項列表,如下:
-bash-3.00# ./configure --help
Usage: configure [options] [host]
Options: [defaults in brackets after descriptions]
Configuration:
–cache-file=FILE cache test results in FILE
–help print this message
–no-create do not create output files
–quiet, --silent do not print `checking…’ messages
–version print the version of autoconf that created configure
Directory and file names:
–prefix=PREFIX install architecture-independent files in PREFIX
[/usr/local]
–exec-prefix=EPREFIX install architecture-dependent files in EPREFIX
[same as prefix]
–bindir=DIR user executables in DIR [EPREFIX/bin]
……….(省略若干)
很多的選項,個人認爲,你可以忽略其他的一切,但請把—prefix加上。這裏以安裝supersparrow-0.0.0爲例,我們打算把它安裝到目錄 /usr/local/supersparrow,於是在supersparrow-0.0.0目錄執行帶選項的腳本./configure --prefix=/usr/local/supersparrow,執行成功後再編譯、安裝(make,make install);安裝完成將自動生成目錄supersparrow,而且該軟件所有的文件都被複制到這個目錄。爲什麼要指定這個安裝目錄?是爲了以後的維護方便,如果沒有用這個選項,安裝過程結束後,該軟件所需的軟件被複制到不同的系統目錄下,很難弄清楚到底複製了那些文件、都複製到哪裏去了—基本上是一塌糊塗。

用了—prefix選項的另一個好處是卸載軟件或移植軟件。當某個安裝的軟件不再需要時,只須簡單的刪除該安裝目錄,就可以把軟件卸載得乾乾淨淨;移植軟件只需拷貝整個目錄到另外一個機器即可(相同的操作系統)。

一個小選項有這麼方便的作用,建議在實際工作中多多使用

‘configure’腳本有大量的命令行選項.對不同的軟件包來說,這些選項可能會有變化,但是許多基本的選項是不會改變的.帶上’–help’選項執行’configure’腳本可以看到可用的所有選項.儘管許多選項是很少用到的,但是當你爲了特殊的需求而configure一個包時,知道他們的存在是很有益處的.下面對每一個選項進行簡略的介紹:

–cache-file=FILE
  'configure’會在你的系統上測試存在的特性(或者bug!).爲了加速隨後進行的配置,測試的結果會存儲在一個cache file裏.當configure一個每個子樹裏都有’configure’腳本的複雜的源碼樹時,一個很好的cache file的存在會有很大幫助.

–help
  輸出幫助信息.即使是有經驗的用戶也偶爾需要使用使用’–help’選項,因爲一個複雜的項目會包含附加的選項.例如,GCC包裏的’configure’腳本就包含了允許你控制是否生成和在GCC中使用GNU彙編器的選項.

–no-create
  'configure’中的一個主要函數會製作輸出文件.此選項阻止’configure’生成這個文件.你可以認爲這是一種演習(dry run),儘管緩存(cache)仍然被改寫了.

–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
  指定二進制文件的安裝位置.這裏的二進制文件定義爲可以被用戶直接執行的程序.

–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下軟件的基本安裝和卸載
Linux軟件的安裝和卸載一直是困擾許多新用戶的難題。在Windows中,我們可以使用軟件自帶的安裝卸載程序或在控制面板中的“添加/刪除程序”來實現。與其相類似,在Linux下有一個功能強大的軟件安裝卸載工具,名爲RPM。它可以用來建立、安裝、查詢、更新、卸載軟件。該工具是在命令行下使用的。在Shell的提示符後輸入rpm,就可獲得該命令的幫助信息。

軟件的安裝

Linux下軟件的安裝主要有兩種不同的形式。第一種安裝文件名爲xxx.tar.gz;另一種安裝文件名爲xxx.i386.rpm。以第一種方式發行的軟件多爲以源碼形式發送的;第二種方式則是直接以二進制形式發送的。

對於第一種,安裝方法如下:

1 .首先,將安裝文件拷貝至你的目錄中。例如,如果你是以root身份登錄上的,就將軟件拷貝至/root中。

#cp xxx.tar.gz /root

2 .由於該文件是被壓縮並打包的,應對其解壓縮。命令爲:

#tar xvzf filename.tar.gz 如果是filename.tar.bz2格式的,應該是tar jxvf filename.tar.bz2來解壓

  1. 執行該命令後,安裝文件按路徑,解壓縮在當前目錄下。用ls命令可以看到解壓縮後的文件。通常在解壓縮後產生的文件中,有“Install”的文件。該文件爲純文本文件,詳細講述了該軟件包的安裝方法。

4.執行解壓縮後產生的一個名爲configure的可執行腳本程序。它是用於檢查系統是否有編譯時所需的庫,以及庫的版本是否滿足編譯的需要等安裝所需要的系統信息。爲隨後的編譯工作做準備。命令爲: #./configure

如果您想把軟件安裝到指定目錄,應該用#./configure --prefix=/您自己指定的目錄,比如我想把一個mlterm安裝到/opt/mlterm目錄中,應該如下輸入

#./configure --prefix=/opt/mlterm

5.檢查通過後,將生成用於編譯的MakeFile文件。此時,可以開始進行編譯了。編譯的過程視軟件的規模和計算機性能的不同,所耗費的時間也不同。命令爲: #make。

6.成功編譯後,鍵入如下的命令開始安裝:

#make install

7.安裝完畢,應清除編譯過程中產生的臨時文件和配置過程中產生的文件。鍵入如下命令:

#make clean

#make distclean

至此,軟件的安裝結束。

對於第二種,其安裝方法要簡單得多。

同第一種方式一樣,將安裝文件拷貝至你的目錄中。然後使用rpm來安裝該文件。命令如下:

#rpm -i filename.i386.rpm

rpm將自動將安裝文件解包,並將軟件安裝到缺省的目錄下。並將軟件的安裝信息註冊到rpm的數據庫中。參數i的作用是使rpm進入安裝模式。

軟件的卸載

1.軟件的卸載主要是使用rpm來進行的。卸載軟件首先要知道軟件包在系統中註冊的名稱。鍵入命令:

#rpm -q -a

即可查詢到當前系統中安裝的所有的軟件包。

  1. 確定了要卸載的軟件的名稱,就可以開始實際卸載該軟件了。鍵入命令:

#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 ,這樣就卸載掉了

‘configure’腳本有大量的命令行選項.對不同的軟件包來說,這些選項可能會有變化,但是許多基本的選項是不會改變的.帶上’-- help’選項執行’configure’腳本能夠看到可用的任何選項.儘管許多選項是很少用到的,但是當您爲了特別的需求而configure一個包時,知道他們的存在是很有益處的.下面對每一個選項進行簡略的介紹:
–cache-file=FILE
  ‘configure’會在您的系統上測試存在的特性(或bug!).爲了加速隨後進行的配置,測試的結果會存儲在一個cache file裏.當configure一個每個子樹裏都有’configure’腳本的複雜的源碼樹時,一個很好的cache file的存在會有很大幫助.
–help
  輸出幫助信息.即使是有經驗的用戶也偶爾需要使用使用’–help’選項,因爲一個複雜的項目會包含附加的選項.例如,GCC包裏的’configure’腳本就包含了允許您控制是否生成和在GCC中使用GNU彙編器的選項.
–no-create
  ‘configure’中的一個主要函數會製作輸出文檔.此選項阻止’configure’生成這個文檔.您能夠認爲這是一種演習(dry run),儘管緩存(cache)仍然被改寫了.
–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
  指定二進制文檔的安裝位置.這裏的二進制文檔定義爲能夠被用戶直接執行的程式.
–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

一個軟件包通過編譯源代碼安裝後,如何完全的卸載??

如果原先的source還在的話,很多source的Makefile都有寫uninstall規則,直接在Souce裏make uninstall就可行,不過碰到無良作者沒寫的,那一句一句看Makefile裏install部分他都幹了些什麼,然後挨個刪除。
如果source沒了…那就一邊鬱悶吧

到目前爲止, 我裝的都可以make uninstall…
(因爲總是不小心裝錯地方, 結果就make uninstall&&make clean,然後重新configure…)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章