Linux 啟動並執行時候,是如何管理共用庫(*.so)的?在 Linux 下面,共用庫的尋找和載入是由 /lib/ld.so 實現的。 ld.so 在標準路經(/lib, /usr/lib) 中尋找應用程式用到的共用庫。
但是,如果需要用到的共用庫在非標準路經,ld.so 怎麼找到它呢?
目前,Linux 通用的做法是將非標準路經加入 /etc/ld.so.conf,然後運行 ldconfig 產生 /etc/ld.so.cache。 ld.so 載入共用庫的時候,會從 ld.so.cache 尋找。
傳 統上, Linux 的先輩 Unix 還有一個環境變數 - LD_LIBRARY_PATH 來處理非標準路經的共用庫。ld.so 載入共用庫的時候,也會尋找這個變數所設定的路經。但是,有不少聲音主張要避免使用 LD_LIBRARY_PATH 變數,尤其是作為全域變數。這些聲音是:
* LD_LIBRARY_PATH is not the answer - http://prefetch.net/articles/linkers.badldlibrary.html
* Why LD_LIBRARY_PATH is bad - http://xahlee.org/UnixResource_dir/_/ldpath.html
* LD_LIBRARY_PATH - just say no - http://blogs.sun.com/rie/date/20040710
解決這一問題的另一方法是在編譯的時候通過 -R<path> 選項指定 run-time path。
1. 往/lib和/usr/lib裡面加東西,是不用修改/etc/ld.so.conf的,但是完了之後要調一下ldconfig,不然這個library會找不到
2. 想往上面兩個目錄以外加東西的時候,一定要修改/etc/ld.so.conf,然後再調用ldconfig,不然也會找不到
比如安裝了一個mysql到/usr/local/mysql,mysql有一大堆library在/usr/local/mysql/lib下面,這時就需要在/etc/ld.so.conf下面加一行/usr/local/mysql/lib,儲存過後ldconfig一下,新的library才能在程式運行時被找到。
3. 如果想在這兩個目錄以外放lib,但是又不想在/etc/ld.so.conf中加東西(或者是沒有許可權加東西)。那也可以,就是export一個全域變數LD_LIBRARY_PATH,然後運行程式的時候就會去這個目錄中找library。一般來講這隻是一種臨時的解決方案,在沒有許可權或臨時需要的時候使用。
4. ldconfig做的這些東西都與運行程式時有關,跟編譯時間一點關係都沒有。編譯的時候還是該加-L就得加,不要混淆了。
5. 總之,就是不管做了什麼關於library的變動後,最好都ldconfig一下,不然會出現一些意想不到的結果。不會花太多的時間,但是會省很多的事。
http://hi.baidu.com/fanzier/blog/item/222ba3ec74cb9a2463d09fb5.html
LD_LIBRARY_PATH 這個環境變數是大家最為熟悉的,它告訴loader:在哪些目錄中可以找到共用庫。可以設定多個搜尋目錄,這些目錄之間用冒號分隔開。在linux下,還提供了另外一種方式來完成同樣的功能,你可以把這些目錄加到/etc/ld.so.conf中,或則在/etc/ld.so.conf.d裡建立一個檔案,把目錄加到這個檔案裡。當然,這是系統範圍內全域有效,而環境變數只對當前shell有效。按照慣例,除非你用上述方式指明,loader是不會在目前的目錄下去找共用庫的,正如shell不會在當前目前找可執行檔一樣。
原文地址 http://hi.baidu.com/cooltown/blog/item/d038a945d1a6be3887947314.html
文章出處:DIY部落(http://www.diybl.com/course/6_system/linux/Linuxjs/20090314/161447.html#)