./configure 的配置和用法

http://blog.csdn.net/u011216417/article/details/46592149java

Linux環境下的軟件安裝,並非一件容易的事情;若是經過源代碼編譯後在安裝,固然事情就更爲複雜一些;如今安裝各類軟件的教程都很是廣泛;但萬變不離其中,對基礎知識的紮實掌握,安裝各類軟件的問題就迎刃而解了。Configure腳本配置工具就是基礎之一,它是autoconf的工具的基本應用。
'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)仍然被改寫了。服務器


--quietapp

--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!)工具


--versionpost

打印用來產生'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=NAME
Kerberos服務主的名稱. 缺省是 「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

相關文章
相關標籤/搜索