## 21.5 函數庫管理
在我們的 Linux 操作系統當中,函數庫是很重要的一個項目。 因為很多的軟件之間都會互相取用彼此提供的函數庫來進行特殊功能的運行, 例如很多需要驗證身份的程序都習慣利用 PAM 這個模塊提供的驗證機制來實作,而很多網絡連線機制則習慣利用 SSL 函數庫來進行連線加密的機制。所以說,函數庫的利用是很重要的。不過, 函數庫又依照是否被編譯到程序內部而分為動態與靜態函數庫,這兩者之間有何差異?哪一種函數庫比較好? 下面我們就來談一談先!
### 21.5.1 動態與靜態函數庫
首先我們要知道的是,函數庫的類型有哪些?依據函數庫被使用的類型而分為兩大類,分別是靜態 (Static) 與動態 (Dynamic) 函數庫兩類。下面我們來談一談這兩種類行的函數庫吧!
* 靜態函數庫的特色:
* **擴展名**:(擴展名為 .a)
這類的函數庫通常擴展名為 libxxx.a 的類型;
* **編譯行為**:
這類函數庫在編譯的時候會直接整合到執行程序當中,所以利用靜態函數庫編譯成的文件會比較大一些喔;
* **獨立執行的狀態**:
這類函數庫最大的優點,就是編譯成功的可可執行文件可以獨立執行,而不需要再向外部要求讀取函數庫的內容 (請參照動態函數庫的說明)。
* **升級難易度**:
雖然可執行文件可以獨立執行,但因為函數庫是直接整合到可執行文件中, 因此若函數庫升級時,整個可執行文件必須要重新編譯才能將新版的函數庫整合到程序當中。 也就是說,在升級方面,只要函數庫升級了,所有將此函數庫納入的程序都需要重新編譯!
* 動態函數庫的特色:
* **擴展名**:(擴展名為 .so)
這類函數庫通常擴展名為 libxxx.so 的類型;
* **編譯行為**:
動態函數庫與靜態函數庫的編譯行為差異挺大的。 與靜態函數庫被整個捉到程序中不同的,動態函數庫在編譯的時候,在程序里面只有一個“指向 (Pointer)”的位置而已。也就是說,動態函數庫的內容并沒有被整合到可執行文件當中,而是當可執行文件要使用到函數庫的機制時, 程序才會去讀取函數庫來使用。由于可執行文件當中僅具有指向動態函數庫所在的指標而已, 并不包含函數庫的內容,所以他的文件會比較小一點。
* **獨立執行的狀態**:
這類型的函數庫所編譯出來的程序不能被獨立執行, 因為當我們使用到函數庫的機制時,程序才會去讀取函數庫,所以函數庫文件“必須要存在”才行,而且,函數庫的“所在目錄也不能改變”,因為我們的可可執行文件里面僅有“指標”亦即當要取用該動態函數庫時, 程序會主動去某個路徑下讀取,呵呵!所以動態函數庫可不能隨意移動或刪除,會影響很多相依的程序軟件喔!
* **升級難易度**:
雖然這類型的可執行文件無法獨立運行,然而由于是具有指向的功能, 所以,當函數庫升級后,可執行文件根本不需要進行重新編譯的行為,因為可執行文件會直接指向新的函數庫文件 (前提是函數庫新舊版本的文件名相同喔!)。
目前的 Linux distribution 比較傾向于使用動態函數庫,因為如同上面提到的最重要的一點, 就是函數庫的升級方便!由于 Linux 系統里面的軟件相依性太復雜了,如果使用太多的靜態函數庫,那么升級某一個函數庫時, 都會對整個系統造成很大的沖擊!因為其他相依的可執行文件也要同時重新編譯啊! 這個時候動態函數庫可就有用多了,因為只要動態函數庫升級就好,其他的軟件根本無須變動。
那么這些函數庫放置在哪里呢?絕大多數的函數庫都放置在:/lib64, /lib 目錄下! 此外,Linux 系統里面很多的函數庫其實 kernel 就提供了,那么 kernel 的函數庫放在哪里?呵呵!就是在 /lib/modules 里面啦!里面的數據可多著呢!不過要注意的是, 不同版本的核心提供的函數庫差異性是挺大的,所以 kernel 2.4.xx 版本的系統不要想將核心換成 2.6.xx 喔! 很容易由于函數庫的不同而導致很多原本可以執行的軟件無法順利運行呢!
### 21.5.2 ldconfig 與 /etc/ld.so.conf
在了解了動態與靜態函數庫,也知道我們目前的 Linux 大多是將函數庫做成動態函數庫之后,再來要知道的就是,那有沒有辦法增加函數庫的讀取性能? 我們知道內存的存取速度是硬盤的好幾倍,所以,如果我們將常用到的動態函數庫先載入內存當中 (高速緩存, cache),如此一來,當軟件要取用動態函數庫時,就不需要從頭由硬盤里面讀出啰! 這樣不就可以增進動態函數庫的讀取速度?沒錯,是這樣的!這個時候就需要 ldconfig 與 /etc/ld.so.conf 的協助了。
如何將動態函數庫載入高速緩存內存當中呢?
1. 首先,我們必須要在 /etc/ld.so.conf 里面寫下“ 想要讀入高速緩存內存當中的動態函數庫所在的目錄”,注意喔, 是目錄而不是文件;
2. 接下來則是利用 ldconfig 這個可執行文件將 /etc/ld.so.conf 的數據讀入高速緩存當中;
3. 同時也將數據記錄一份在 /etc/ld.so.cache 這個文件當中吶!
圖21.5.1、使用 ldconfig 預載入動態函數庫到內存中
事實上, ldconfig 還可以用來判斷動態函數庫的鏈接信息呢!趕緊利用 CentOS 來測試看看。假設你想要將目前你系統下的 mariadb 函數庫加入到高速緩存當中時,可以這樣做:
```
[root@study ~]# ldconfig [-f conf] [ -C cache]
[root@study ~]# ldconfig [-p]
選項與參數:
-f conf :那個 conf 指的是某個文件名稱,也就是說,使用 conf 作為 libarary
函數庫的取得路徑,而不以 /etc/ld.so.conf 為默認值
-C cache:那個 cache 指的是某個文件名稱,也就是說,使用 cache 作為高速緩存暫存
的函數庫數據,而不以 /etc/ld.so.cache 為默認值
-p :列出目前有的所有函數庫數據內容 (在 /etc/ld.so.cache 內的數據!)
范例一:假設我的 Mariadb 數據庫函數庫在 /usr/lib64/mysql 當中,如何讀進 cache ?
[root@study ~]# vim /etc/ld.so.conf.d/vbird.conf
/usr/lib64/mysql <==這一行新增的啦!
[root@study ~]# ldconfig <==畫面上不會顯示任何的信息,不要太緊張!正常的!
[root@study ~]# ldconfig -p
924 libs found in cache `/etc/ld.so.cache'
p11-kit-trust.so (libc6,x86-64) => /lib64/p11-kit-trust.so
libzapojit-0.0.so.0 (libc6,x86-64) => /lib64/libzapojit-0.0.so.0
....(下面省略)....
# 函數庫名稱 => 該函數庫實際路徑
```
通過上面的動作,我們可以將 Mariadb 的相關函數庫給他讀入高速緩存當中,這樣可以加快函數庫讀取的效率呢! 在某些時候,你可能會自行加入某些 Tarball 安裝的動態函數庫,而你想要讓這些動態函數庫的相關鏈接可以被讀入到高速緩存當中, 這個時候你可以將動態函數庫所在的目錄名稱寫入 /etc/ld.so.conf.d/yourfile.conf 當中,然后執行 ldconfig 就可以啦!
### 21.5.3 程序的動態函數庫解析: ldd
說了這么多,那么我如何判斷某個可執行的 binary 文件含有什么動態函數庫呢?很簡單,利用 ldd 就可以曉得了!例如我想要知道 /usr/bin/passwd 這個程序含有的動態函數庫有哪些,可以這樣做:
```
[root@study ~]# ldd [-vdr] [filename]
選項與參數:
-v :列出所有內容信息;
-d :重新將數據有遺失的 link 點秀出來!
-r :將 ELF 有關的錯誤內容秀出來!
范例一:找出 /usr/bin/passwd 這個文件的函數庫數據
[root@study ~]# ldd /usr/bin/passwd
....(前面省略)....
libpam.so.0 => /lib64/libpam.so.0 (0x00007f5e683dd000) <==PAM 模塊
libpam_misc.so.0 => /lib64/libpam_misc.so.0 (0x00007f5e681d8000)
libaudit.so.1 => /lib64/libaudit.so.1 (0x00007f5e67fb1000) <==SELinux
libselinux.so.1 => /lib64/libselinux.so.1 (0x00007f5e67d8c000) <==SELinux
....(下面省略)....
# 我們前言的部分不是一直提到 passwd 有使用到 pam 的模塊嗎!怎么知道?
# 利用 ldd 察看一下這個文件,看到 libpam.so 了吧?這就是 pam 提供的函數庫
范例二:找出 /lib64/libc.so.6 這個函數的相關其他函數庫!
[root@study ~]# ldd -v /lib64/libc.so.6
/lib64/ld-linux-x86-64.so.2 (0x00007f7acc68f000)
linux-vdso.so.1 => (0x00007fffa975b000)
Version information: <==使用 -v 選項,增加顯示其他版本信息!
/lib64/libc.so.6:
ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2
ld-linux-x86-64.so.2 (GLIBC_PRIVATE) => /lib64/ld-linux-x86-64.so.2
```
未來如果你常常升級安裝 RPM 的軟件時 (下一章節會介紹),應該常常會發現那個“ 相依屬性”的問題吧!沒錯!我們可以先以 ldd 來視察“相依函數庫”之間的相關性!以先取得了解! 例如上面的例子中,我們檢查了 libc.so.6 這個在 /lib64 當中的函數庫,結果發現他其實還跟 ld-linux-x86-64.so.2 有關!所以我們就需要來了解一下,那個文件到底是什么軟件的函數庫呀?使用 -v 這個參數還可以得知該函數庫來自于哪一個軟件!像上面的數據中,就可以得到該 libc.so.6 其實可以支持 GLIBC_2.3 等的版本!
- 鳥哥的Linux私房菜:基礎學習篇 第四版
- 目錄及概述
- 第零章、計算機概論
- 0.1 電腦:輔助人腦的好工具
- 0.2 個人電腦架構與相關設備元件
- 0.3 數據表示方式
- 0.4 軟件程序運行
- 0.5 重點回顧
- 0.6 本章習題
- 0.7 參考資料與延伸閱讀
- 第一章、Linux是什么與如何學習
- 1.1 Linux是什么
- 1.2 Torvalds的Linux發展
- 1.3 Linux當前應用的角色
- 1.4 Linux 該如何學習
- 1.5 重點回顧
- 1.6 本章習題
- 1.7 參考資料與延伸閱讀
- 第二章、主機規劃與磁盤分區
- 2.1 Linux與硬件的搭配
- 2.2 磁盤分區
- 2.3 安裝Linux前的規劃
- 2.4 重點回顧
- 2.5 本章習題
- 2.6 參考資料與延伸閱讀
- 第三章、安裝 CentOS7.x
- 3.1 本練習機的規劃--尤其是分區參數
- 3.2 開始安裝CentOS 7
- 3.3 多重開機安裝流程與管理(Option)
- 3.4 重點回顧
- 3.5 本章習題
- 3.6 參考資料與延伸閱讀
- 第四章、首次登陸與線上求助
- 4.1 首次登陸系統
- 4.2 文字模式下指令的下達
- 4.3 Linux系統的線上求助man page與info page
- 4.4 超簡單文書編輯器: nano
- 4.5 正確的關機方法
- 4.6 重點回顧
- 4.7 本章習題
- 4.8 參考資料與延伸閱讀
- 第五章、Linux 的文件權限與目錄配置
- 5.1 使用者與群組
- 5.2 Linux 文件權限概念
- 5.3 Linux目錄配置
- 5.4 重點回顧
- 5.5 本章練習
- 5.6 參考資料與延伸閱讀
- 第六章、Linux 文件與目錄管理
- 6.1 目錄與路徑
- 6.2 文件與目錄管理
- 6.3 文件內容查閱
- 6.4 文件與目錄的默認權限與隱藏權限
- 6.5 指令與文件的搜尋
- 6.6 極重要的復習!權限與指令間的關系
- 6.7 重點回顧
- 6.8 本章習題:
- 6.9 參考資料與延伸閱讀
- 第七章、Linux 磁盤與文件系統管理
- 7.1 認識 Linux 文件系統
- 7.2 文件系統的簡單操作
- 7.3 磁盤的分區、格式化、檢驗與掛載
- 7.4 設置開機掛載
- 7.5 內存交換空間(swap)之創建
- 7.6 文件系統的特殊觀察與操作
- 7.7 重點回顧
- 7.8 本章習題 - 第一題一定要做
- 7.9 參考資料與延伸閱讀
- 第八章、文件與文件系統的壓縮,打包與備份
- 8.1 壓縮文件的用途與技術
- 8.2 Linux 系統常見的壓縮指令
- 8.3 打包指令: tar
- 8.4 XFS 文件系統的備份與還原
- 8.5 光盤寫入工具
- 8.6 其他常見的壓縮與備份工具
- 8.7 重點回顧
- 8.8 本章習題
- 8.9 參考資料與延伸閱讀
- 第九章、vim 程序編輯器
- 9.1 vi 與 vim
- 9.2 vi 的使用
- 9.3 vim 的額外功能
- 9.4 其他 vim 使用注意事項
- 9.5 重點回顧
- 9.6 本章練習
- 9.7 參考資料與延伸閱讀
- 第十章、認識與學習BASH
- 10.1 認識 BASH 這個 Shell
- 10.2 Shell 的變量功能
- 10.3 命令別名與歷史命令
- 10.4 Bash Shell 的操作環境:
- 10.5 數據流重導向
- 10.6 管線命令 (pipe)
- 10.7 重點回顧
- 10.8 本章習題
- 10.9 參考資料與延伸閱讀
- 第十一章、正則表達式與文件格式化處理
- 11.1 開始之前:什么是正則表達式
- 11.2 基礎正則表達式
- 11.3 延伸正則表達式
- 11.4 文件的格式化與相關處理
- 11.5 重點回顧
- 11.6 本章習題
- 11.7 參考資料與延伸閱讀
- 第十二章、學習 Shell Scripts
- 12.1 什么是 Shell scripts
- 12.2 簡單的 shell script 練習
- 12.3 善用判斷式
- 12.4 條件判斷式
- 12.5 循環 (loop)
- 12.6 shell script 的追蹤與 debug
- 12.7 重點回顧
- 12.8 本章習題
- 第十三章、Linux 帳號管理與 ACL 權限設置
- 13.1 Linux 的帳號與群組
- 13.2 帳號管理
- 13.3 主機的細部權限規劃:ACL 的使用
- 13.4 使用者身份切換
- 13.5 使用者的特殊 shell 與 PAM 模塊
- 13.6 Linux 主機上的使用者訊息傳遞
- 13.7 CentOS 7 環境下大量創建帳號的方法
- 13.8 重點回顧
- 13.9 本章習題
- 13.10 參考資料與延伸閱讀
- 第十四章、磁盤配額(Quota)與進階文件系統管理
- 14.1 磁盤配額 (Quota) 的應用與實作
- 14.2 軟件磁盤陣列 (Software RAID)
- 14.3 邏輯卷軸管理員 (Logical Volume Manager)
- 14.4 重點回顧
- 14.5 本章習題
- 14.6 參考資料與延伸閱讀
- 第十五章、例行性工作調度(crontab)
- 15.1 什么是例行性工作調度
- 15.2 僅執行一次的工作調度
- 15.3 循環執行的例行性工作調度
- 15.4 可喚醒停機期間的工作任務
- 15.5 重點回顧
- 15.6 本章習題
- 第十六章、程序管理與 SELinux 初探
- 16.1 什么是程序 (process)
- 16.2 工作管理 (job control)
- 16.3 程序管理
- 16.4 特殊文件與程序
- 16.5 SELinux 初探
- 16.6 重點回顧
- 16.7 本章習題
- 16.8 參考資料與延伸閱讀
- 第十七章、認識系統服務 (daemons)
- 17.1 什么是 daemon 與服務 (service)
- 17.2 通過 systemctl 管理服務
- 17.3 systemctl 針對 service 類型的配置文件
- 17.4 systemctl 針對 timer 的配置文件
- 17.5 CentOS 7.x 默認啟動的服務簡易說明
- 17.6 重點回顧
- 17.7 本章習題
- 17.8 參考資料與延伸閱讀
- 第十八章、認識與分析登錄文件
- 18.1 什么是登錄文件
- 18.2 rsyslog.service :記錄登錄文件的服務
- 18.3 登錄文件的輪替(logrotate)
- 18.4 systemd-journald.service 簡介
- 18.5 分析登錄文件
- 18.6 重點回顧
- 18.7 本章習題
- 18.8 參考資料與延伸閱讀
- 第十九章、開機流程、模塊管理與 Loader
- 19.1 Linux 的開機流程分析
- 19.2 核心與核心模塊
- 19.3 Boot Loader: Grub2
- 19.4 開機過程的問題解決
- 19.5 重點回顧
- 19.6 本章習題
- 19.7 參考資料與延伸閱讀
- 第二十章、基礎系統設置與備份策略
- 20.1 系統基本設置
- 20.2 服務器硬件數據的收集
- 20.3 備份要點
- 20.4 備份的種類、頻率與工具的選擇
- 20.5 鳥哥的備份策略
- 20.6 災難復原的考慮
- 20.7 重點回顧
- 20.8 本章習題
- 20.9 參考資料與延伸閱讀
- 第二十一章、軟件安裝:源代碼與 Tarball
- 20.1 開放源碼的軟件安裝與升級簡介
- 21.2 使用傳統程序語言進行編譯的簡單范例
- 21.3 用 make 進行宏編譯
- 21.4 Tarball 的管理與建議
- 21.5 函數庫管理
- 21.6 檢驗軟件正確性
- 21.7 重點回顧
- 21.8 本章習題
- 21.9 參考資料與延伸閱讀
- 第二十二章、軟件安裝 RPM, SRPM 與 YUM
- 22.1 軟件管理員簡介
- 22.2 RPM 軟件管理程序: rpm
- 22.3 YUM 線上升級機制
- 22.4 SRPM 的使用 : rpmbuild (Optional)
- 22.5 重點回顧
- 22.6 本章習題
- 22.7 參考資料與延伸閱讀
- 第二十三章、X Window 設置介紹
- 23.1 什么是 X Window System
- 23.2 X Server 配置文件解析與設置
- 23.3 顯卡驅動程序安裝范例
- 23.4 重點回顧
- 23.5 本章習題
- 23.6 參考資料與延伸閱讀
- 第二十四章、Linux 核心編譯與管理
- 24.1 編譯前的任務:認識核心與取得核心源代碼
- 24.2 核心編譯的前處理與核心功能選擇
- 24.3 核心的編譯與安裝
- 24.4 額外(單一)核心模塊編譯
- 24.5 以最新核心版本編譯 CentOS 7.x 的核心
- 24.6 重點回顧
- 24.7 本章習題
- 24.8 參考資料與延伸閱讀