欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

<-
Apache > HTTP Server > 文檔 > 版本2.2
   致謝 | 譯者聲明 | 本篇譯者:金步國 | 本篇譯稿最后更新:2006年1月2日 | 獲取最新版本

動態(tài)共享對象(DSO)支持

Apache HTTP服務(wù)器是一個模塊化的軟件,管理員可以通過選擇服務(wù)器中包含的模塊進(jìn)行功能增減。模塊可以在編譯時被靜態(tài)包含進(jìn)httpd二進(jìn)制文件,也可以編譯成獨(dú)立于httpd二進(jìn)制文件的動態(tài)共享對象(DSO)。DSO模塊可以與服務(wù)器一起編譯,也可以用Apache擴(kuò)展工具(apxs)單獨(dú)編譯。

本文闡述如何使用DSO模塊及其工作原理。

top

實(shí)現(xiàn)

Apache對獨(dú)立模塊的DSO支持是建立在只能被靜態(tài)編譯進(jìn)Apache核心的mod_so基礎(chǔ)之上的,這是core以外唯一不能作為DSO存在的模塊,而其他所有已發(fā)布的Apache模塊,都可以通過安裝文檔中闡述中的編譯選項(xiàng) --enable-module=shared 被獨(dú)立地編譯成DSO并使之生效。一個被編譯為mod_foo.so的DSO模塊,可以在httpd.conf中使用mod_soLoadModule指令,在服務(wù)器啟動或重新啟動時被加載。

新提供的支持程序apxs(APache eXtenSion)可以在Apache源代碼樹之外編譯基于DSO的模塊,從而簡化了Apache DSO模塊的建立過程。其原理很簡單:安裝Apache時,configuremake install 命令會安裝Apache C頭文件,并把依賴于特定平臺的編譯器和連接器參數(shù)傳給apxs程序,使用戶可以脫離Apache的發(fā)布源代碼樹編譯其模塊源代碼,而不改變支持DSO的編譯器和連接器的參數(shù)。

top

用法概要

Apache2.0 的DSO功能簡要說明:

  1. 編譯并安裝已發(fā)布的Apache模塊,比如編譯mod_foo.cmod_foo.so的DSO模塊:

    $ ./configure --prefix=/path/to/install --enable-foo=shared
    $ make install

  2. 編譯并安裝第三方模塊,比如編譯mod_foo.cmod_foo.so的DSO模塊:

    $ ./configure --add-module=module_type:/path/to/3rdparty/mod_foo.c --enable-foo=shared
    $ make install

  3. 配置Apache以便以后安裝共享模塊:

    $ ./configure --enable-so
    $ make install

  4. apxs在Apache源碼樹以外編譯并安裝第三方模塊,比如編譯mod_foo.cmod_foo.so的DSO模塊:

    $ cd /path/to/3rdparty
    $ apxs -c mod_foo.c
    $ apxs -i -a -n foo mod_foo.la

共享模塊編譯完畢后,必須在httpd.conf中用LoadModule指令使Apache啟用該模塊。

top

背景知識

現(xiàn)代的類Unix系統(tǒng)都有一種叫動態(tài)共享對象(DSO)的動態(tài)連接/加載的巧妙的機(jī)制,從而可以在運(yùn)行時將編譯成特殊格式的代碼加載到一個可執(zhí)行程序的地址空間。

加載的方法通常有兩種:其一是在可執(zhí)行文件啟動時由系統(tǒng)程序ld.so自動加載;其二是在可執(zhí)行程序中手動地通過Unix加載器的系統(tǒng)接口執(zhí)行系統(tǒng)調(diào)用dlopen()/dlsym()進(jìn)行加載。

按第一種方法,DSO通常被稱為共享庫(shared libraries)或者DSO庫(DSO libraries),使用libfoo.solibfoo.so.1.2的文件名,存儲在系統(tǒng)目錄中(通常是/usr/lib),并在編譯安裝時使用連接器參數(shù) -lfoo 建立了指向可執(zhí)行程序的連接。通過設(shè)置連接器參數(shù) -R 或者環(huán)境變量LD_LIBRARY_PATH ,庫中硬編碼了可執(zhí)行文件的路徑,使Unix加載器能夠在可執(zhí)行程序啟動時定位到位于/usr/lib目錄中的libfoo.so ,以解析可執(zhí)行文件中尚未解析的位于DSO中的符號。

通常,DSO不會引用可執(zhí)行文件中的符號(因?yàn)樗峭ㄓ么a的可重用庫),也不會有后繼的解析動作?蓤(zhí)行文件無須自己作任何動作以使用DSO中的符號,而完全由Unix加載器代辦(事實(shí)上,調(diào)用ld.so的代碼是被連入每個可執(zhí)行文件的非靜態(tài)運(yùn)行時啟動代碼的一部分)。動態(tài)加載公共庫代碼的優(yōu)點(diǎn)是明顯的:只需要在系統(tǒng)庫libc.so中存儲一次庫代碼,從而為每個程序節(jié)省了磁盤存儲空間。

按第二種方法,DSO通常被稱為共享對象(shared objects)或DSO文件(DSO files),可以使用任何文件名(但是規(guī)范的名稱是foo.so),被存儲在程序特定的目錄中,也不會自動建立指向其所用的可執(zhí)行文件的連接,而由可執(zhí)行文件在運(yùn)行時自己調(diào)用dlopen()來加載DSO到其地址空間,同時也不會進(jìn)行為可執(zhí)行文件解析DSO中符號的操作。Unix加載器會根據(jù)可執(zhí)行程序的輸出符號表和已經(jīng)加載的DSO庫自動解析DSO中尚未解析的符號(尤其是無所不在的libc.so中的符號),如此DSO就獲得了可執(zhí)行程序的符號信息,就好象是被靜態(tài)連接一樣。

最后,為了利用DSO API的優(yōu)點(diǎn),可執(zhí)行程序必須用dlsym()解析DSO中的符號,以備稍后在諸如指派表等等中使用。也就是說,可執(zhí)行程序必須自己解析其所需的符號。這種機(jī)制的優(yōu)點(diǎn)是允許不加載可選的程序部件,直到程序需要的時候才被動態(tài)地加載(也就不需要內(nèi)存開銷),以擴(kuò)展程序的功能。

雖然這種DSO機(jī)制看似很直接,但至少有一個難點(diǎn),就是在用DSO擴(kuò)展程序功能(第二種方法)時為DSO對可執(zhí)行程序中符號的進(jìn)行解析,這是因?yàn)椋?反向解析"可執(zhí)行程序中的DSO符號在所有標(biāo)準(zhǔn)平臺上與庫的設(shè)計(jì)都是矛盾的(庫不會知道什么程序會使用它)。實(shí)際應(yīng)用中,可執(zhí)行文件中的全局符號通常不是重輸出的,因此不能為DSO所用。所以在運(yùn)行時用DSO來擴(kuò)展程序功能,就必須找到強(qiáng)制連接器輸出所有全局符號的方法。

共享庫是一種典型的解決方法,因?yàn)樗螪SO機(jī)制,而且為操作系統(tǒng)所提供的幾乎所有類型的庫所使用。另一方面,使用共享對象并不是許多程序?yàn)閿U(kuò)展其功能所采用的方法。

截止到1998年,只有少數(shù)的軟件包使用DSO機(jī)制在運(yùn)行時擴(kuò)展其功能,諸如 Perl 5(通過其XS機(jī)制和DynaLoader模塊),Netscape Server等。從1.3版本開始,Apache也加入此列,因?yàn)锳pache已經(jīng)用了基于指派表(dispatch-list-based)的方法來連接外部模塊到Apache的核心。所以Apache也就當(dāng)然地在運(yùn)行時用DSO來加載其模塊。

top

優(yōu)點(diǎn)和缺點(diǎn)

上述基于DSO的功能有如下優(yōu)點(diǎn):

DSO有如下缺點(diǎn):