可執行程序找不到要鏈接的動態共享庫,這是Linux上面編譯和運行程序很容易碰到的問題,通過上面的小例子,我們已經大致瞭解
共享庫的一點基本原理,接下來我們要探討一下怎麼設置程序尋找動態共享庫的行爲。
Linux操作系統上面的動態共享庫大致分爲三類:
1、操作系統級別的共享庫和基礎的系統工具庫
比方說libc.so, libz.so, libpthread.so等等,這些系統庫會被放在/lib和/usr/lib目錄下面,如果是64位操作系統,還會
有/lib64和/usr /lib64目錄。如果操作系統帶有圖形界面,那麼還會有/usr/X11R6/lib目錄,如果是64位操作系統,還
有/usr/X11R6 /lib64目錄。此外還可能有其他特定Linux版本的系統庫目錄。
這些系統庫文件的完整和版本的正確,確保了Linux上面各種程序能夠正常的運行。
2、應用程序級別的系統共享庫
並非操作系統自帶,但是可能被很多應用程序所共享的庫,一般會被放在/usr/local/lib和/usr/local/lib64這兩個目錄下面。很多
你自行編譯安裝的程序都會在編譯的時候自動把/usr/local/lib加入gcc的-L參數,而在運行的時候自動到/usr/local/lib下面去尋
找共享庫。
以上兩類的動態共享庫,應用程序會自動尋找到他們,並不需要你額外的設置和擔心。這是爲什麼呢?因爲以上這些目錄默認就被加
入到動態鏈接程序的搜索路徑裏面了。Linux的系統共享庫搜索路徑定義在/etc/ld.so.conf這個配置文件裏面。這個文件的內容格式
大致如下:
1. /usr/X11R6/lib64
2. /usr/X11R6/lib
3. /usr/local/lib
4. /lib64
5. /lib
6. /usr/lib64
7. /usr/lib
8. /usr/local/lib64
9. /usr/local/ImageMagick/lib
假設我們自己編譯安裝的ImageMagick圖形庫在/usr/local/ImageMagick目錄下面,並且希望其他應用程序都可以使用ImageMagick的
動態共享庫,那麼我們只需要把/usr/local/ImageMagick/lib目錄加入/etc /ld.so.conf文件裏面,然後執行:ldconfig 命令即可。
ldcofig將搜索以上所有的目錄,爲共享庫建立一個緩存文件/etc/ld.so.cache。爲了確認ldconfig已經搜索到ImageMagick的庫,我
們可以用上面介紹的strings命令從ld.so.cache裏面抽取文本信息來檢查一下:
1. strings /etc/ld.so.cache | grep ImageMagick
輸出結果爲:
1. /usr/local/ImageMagick/lib/libWand.so.10
2. /usr/local/ImageMagick/lib/libWand.so
3. /usr/local/ImageMagick/lib/libMagick.so.10
4. /usr/local/ImageMagick/lib/libMagick.so
5. /usr/local/ImageMagick/lib/libMagick++.so.10
6. /usr/local/ImageMagick/lib/libMagick++.so
已經成功了!
3、應用程序獨享的動態共享庫
有很多共享庫只被特定的應用程序使用,那麼就沒有必要加入系統庫路徑,以免應用程序的共享庫之間發生版本衝突。因此Linux還
可以通過設置環境變量 LD_LIBRARY_PATH來臨時指定應用程序的共享庫搜索路徑,就像我們上面舉的那個例子一樣,我們可以在應用
程序的啓動腳本里面預先設置 LD_LIBRARY_PATH,指定本應用程序附加的共享庫搜索路徑,從而讓應用程序找到它。