Linux環境下的軟體安裝,并不是一件容易的事情;如果通過源代碼編譯後在安裝,當然事情就更為複雜一些;現在安裝各種軟體的教程都非常普遍;但萬變不離其中,對基礎知識的紮實掌握,安裝各種軟體的問題就迎刃而解了。Configure腳本配置工具就是基礎之一,它是autoconf的工具的基本應用。'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庫的目錄的方法。
--with-krb-srvnam=NAMEKerberos服務主的名稱. 預設是 “postgres”.通常沒有理由改變這個值.--with-openssl=DIRECTORY制作支援 SSL (加密的)聯接的postgres. 這個選項需要安裝 OpenSSL 包. DIRECTORY 參數聲明 OpenSSL 安裝的根目錄;預設時 /usr/local/ssl.configure 将在安裝之前檢查所需要的頭檔案和庫檔案以确信你的 OpenSSL 安裝是充分的.--with-java制作 JDBC 驅動以及相關的 Java 包. 這個選項要求你先安裝 Ant (當然還要有 JDK). 請參考程式員手冊 裡面 JDBC 驅動的文檔擷取更多資訊.--enable-syslog打開PostgreSQL 伺服器使用 syslog 日志系統的功能. (使用這個功能并不意味着你必須用 syslog 做日志,也不是說 伺服器預設會做這些,而是給你一個在運作時使用這個選項目的可能.)--enable-debug把 所有程式和庫以帶有調試符号的方式編譯. 這意味着你可以通過一個調試器運作程式來分析問題. 這樣做顯著增大了最後安裝的可執行檔案的大小, 并且在非 gcc 的編譯器上,這麼做通常還要關閉編譯器優化, 導緻速度的下降.但是,如果有這些符号表的話,就可以極大 幫助定位可能發生問題的位置.目前,我們認為這個選項對于 生産用途而言是邊際變量,但是如果你正在進行開發工作,或者正在使用 beta 版本, 那麼你就應該打開它.--enable-cassert打開在伺服器中的 assertion 檢查, 它會檢查許多“不可能發生”的條件.它對于代碼開發的用途 而言是無價之寶,不過這些測試稍微地減慢了一些速度. 這些斷言檢查并不一定都是針對嚴重錯誤的,是以一些相對無害的 小蟲子也可能導緻 postmaster 重新開機--隻要它觸發了一次斷言失敗. 目前,我們不推薦在生産環境中使用這個選項,但是如果你在做開發 或者在使用 beta 版本的時候應該打開它.如果你喜歡用那些和 configure 找出來的不同的 編譯器,那麼你可以分别設定你的環境變量 CC 和 CXX,把它們設定為你選擇的程式. 類似地,你可以用 CFLAGS 和 CXXFLAGS 變量覆寫預設編譯器标志.比如:env CC=/opt/bin/gcc CFLAGS='-02 -pipe' ./configure
在源碼樹中運作'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