主頁 > 知識庫 > Linux下軟件包類故障排錯方案詳解

Linux下軟件包類故障排錯方案詳解

熱門標簽:電話機器人搭建 服務器配置 解決方案 外呼系統(tǒng) 百度競價點擊價格的計算公式 硅谷的囚徒呼叫中心 美團 家政服務網(wǎng)絡

軟件包類故障在Linux系統(tǒng)中比較常見,例如:需要編譯源碼包程序時系統(tǒng)中沒有安裝gcc編譯工具,安裝RPM軟件包時有未解決的依賴關系,程序庫文件或頭文件的安裝路徑不正確等,軟件包類故障產(chǎn)生的原因非常多,通常只需要根據(jù)相應的錯誤提示信息,確認安裝好編譯環(huán)境,找到所需要的依賴軟件包,糾正庫文件或對應的頭文件路徑即可。

下面主要介紹rpm數(shù)據(jù)庫損壞和找不到“.so”文件的故障解決方法。

1、rpm數(shù)據(jù)庫損壞

rpm數(shù)據(jù)庫損壞的故障并不多見,出現(xiàn)該故障的原因一般是由于經(jīng)常強制關機,誤刪除運行中的文件,強制替換一些rpm包文件等。rpm數(shù)據(jù)庫損壞后,在使用rpm工具查詢或安裝軟件時,將無法正常運行。

eg:模擬rpm數(shù)據(jù)庫損壞故障,并驗證錯誤信息。

RPM作為Linux系統(tǒng)中的軟件包管理機制,維護著一份獨立的文件數(shù)據(jù)庫,用于存儲在系統(tǒng)中已安裝的rpm包信息。當數(shù)據(jù)文件損壞時,將導致不能使用rpm命令或yum命令來查詢、安裝、升級、刪除rpm類軟件包。解決該故障一般只需要執(zhí)行"rpm --rebuilddb"命令,重建數(shù)據(jù)庫即可。     

Ps:本系統(tǒng)httpd包已經(jīng)安裝!

eg:清除損壞的rpm數(shù)據(jù)文件,并重建數(shù)據(jù)庫信息。

看圖提示可以了吧!

2、缺少*.so類文件

在通過源碼編譯的方式安裝軟件包時,程序的可執(zhí)行文件、函數(shù)庫、配置文件等一般會默認安裝到"/usr/local'目錄下的相應位置(前提是你的程序安裝在"/usr/local"下喔,比如:/usr/local/mysql/bin、/usr/local/mysql/lib等),以便與系統(tǒng)程序的相關目錄區(qū)別開來。

*.so文件就如同Windows系統(tǒng)中的.dll文件一樣,是庫文件。一個程序的正常安裝和運行需要特定庫文件的支持。由于類似于"/usr/local/mysql/lib"的目錄并不包括在Linux系統(tǒng)的默認庫文件路徑下,當安裝其他軟件包時,如果需要用到這些目錄中的動態(tài)鏈接庫文件,將會無法找到,從而出現(xiàn)缺少".so"文件的錯誤信息。

在RHEL5系統(tǒng)中,配置文件“/etc/ld.so.conf”記錄了動態(tài)鏈接庫的默認搜索路徑。當需要添加新的庫文件搜索路徑時,則必須在該文件中進行相應修改,修改完畢后執(zhí)行"ldconfig"命令,重新讀取新的配置信息。

eg:將"/usr/local/mysql/lib/mysql'目錄添加到系統(tǒng)的庫文件搜索路徑中。

vi /etc/ld.so.conf                //在文件末尾添加一行記錄

/usr/local/mysql/lib/mysql

ldconfig

當安裝新的應用程序時,如果提示缺少".so"文件,應首先使用find命令查找系統(tǒng)中是否存在對應的文件,若不存在則表示提供該鏈接庫的依賴軟件并沒有安裝,需要先獲取相應的軟件包并安裝才行。若在系統(tǒng)中已經(jīng)存在對應的".so"文件,則可以通過上述修改ld.so.conf文件的方法解決庫文件搜索的問題。

3、修復文件系統(tǒng)

Linux主機經(jīng)常因為非正常關機、突然斷電、設備數(shù)據(jù)讀寫異常等原因導致文件系統(tǒng)的破壞。比較常見的是超級塊(super-block)損壞,超級塊是文件系統(tǒng)的核心"檔案",它記錄了該文件系統(tǒng)的類型、大小、空閑磁盤塊等信息。當文件系統(tǒng)的超級塊數(shù)據(jù)損壞時,Linux將無法識別該文件系統(tǒng),也就無法掛載使用。

當通過"/etc/fstab"配置文件自動加載的文件系統(tǒng)出現(xiàn)錯誤時,Linux系統(tǒng)開機后一般會自動進行檢測,并提示用戶需要進行文件系統(tǒng)的修復操作,例如:當"/dev/sdb1"分區(qū)的超級塊出現(xiàn)錯誤時,啟動后系統(tǒng)將提示"Give root password for maintenance"

這時只需要輸入root用戶的密碼,即可進入到一個臨時的Shell環(huán)境,在這里用戶可以對出現(xiàn)錯誤的文件系統(tǒng)進行修復。修復一般的文件系統(tǒng)錯誤可以使用fsck命令,結合"-t"選項指定文件系統(tǒng)類型,結合“-y”選擇對發(fā)現(xiàn)的問題自動回答“yes”。需要注意的是,如果該文件系統(tǒng)遭受破壞的情況很嚴重,則修復完畢后可能仍然會丟失一些數(shù)據(jù),因此請慎重決定是否進行修復。

eg:使用fsck命令修復位于"/dev/sdb1"分區(qū)中的ext3文件系統(tǒng)。

fsck -yt ext3 /dev/sdb1

exit                    //退出臨時Shell環(huán)境后將自動重啟。

4、磁盤資料耗盡故障

顯而易見,當一個文件系統(tǒng)的磁盤空間被耗盡以后,將無法繼續(xù)在該分區(qū)創(chuàng)建新的文件數(shù)據(jù),從而導致故障的出現(xiàn),例如:當根分區(qū)"/"中的磁盤空間耗盡以后,將可能導致部分程序乃至整個系統(tǒng)無法正常啟動或進行,因為一些臨時的運行文件將無法建立。

當根分區(qū)磁盤空間不足無法啟動進入Linux系統(tǒng)時,可以通過RHEL5的光盤進入急救模式,轉移或清除掉根分區(qū)占用大量空間的文件。過程不再描述。

除此以外,當ext3文件系統(tǒng)中,i節(jié)點作為文件的索引節(jié)點,決定了該磁盤中文件數(shù)據(jù)的存儲位置。當一個文件系統(tǒng)被創(chuàng)建以后,其i節(jié)點數(shù)就已經(jīng)固定下來了,從而在該文件系統(tǒng)中能夠使用的文件數(shù)量也就固定下來了。如果用戶在該分區(qū)中創(chuàng)建了巨量的細小文件(耗盡i節(jié)點),將可能出現(xiàn)這種情況;雖然該分區(qū)中仍然有大量的剩余磁盤空間,但是用戶卻無法再 建立新的文件。

4.1、模擬i節(jié)點耗盡故障

eg:1、以一個20M的ext3文件系統(tǒng)為例(“/dev/sdb2”),將其掛載到"/data"目錄下。并使用帶“-i”選項的df命令確認該分區(qū)的i節(jié)點的使用情況。

4.2、編寫一個循環(huán)創(chuàng)建空文件的腳本程序,運行該腳本直至耗盡sdb2分區(qū)中的i節(jié)點。

4.3、i節(jié)點耗盡以后,再次創(chuàng)建新的文件時,將會出現(xiàn)"設備上沒有空間"的錯誤信息,但是使用df命令可以查看到該分區(qū)中還有可用的剩余空間,只是i節(jié)點數(shù)已經(jīng)用完。

4.4、修復i節(jié)點耗盡故障

理解i節(jié)點耗盡故障的根結以后,問題就好了點了,只要找出該分區(qū)中占用大量i節(jié)點的細小文件,并進行轉移或者刪除即可。

rm -rf `find /data -empty -a -type f`

5、無法卸載已掛載的設備

在Linux系統(tǒng)中,通過umount命令卸載光驅等設備時,有時候會出現(xiàn)"device is busy"的提示信息,而無法卸載。這表示"設備正忙",很可能是由于用戶或者其他程序正在使用設備的資料而造成的,系統(tǒng)基于保護性考慮,將禁止直接卸載該設備。

eg:當用戶的當前功能路徑位于光盤中的目錄時,將無法卸載該光盤設備。

由于umount命令并不會告知是那個用戶、程序正在使用該設備中的資源,因此在當前登錄的用戶數(shù)量較多、進程結構復雜的情況下會很難定位正在使用該目錄的進程。使用fuser命令可以幫助解決這個問題

fuser命令用戶找出正在使用某個設備或文件/目錄的用戶、程序等相關信息。通過“-m”選項可以指定相應的文件或目錄,“-v”選項可以顯示詳細信息。如果使用"-k"選項,還可以強制關閉正在使用該文件或目錄的進程(當然,也可以使用kill命令終止該進程。)

eg:查看正在使用"/media"目錄的用戶、進程等相關信息,然后關閉正在使用該目錄的進程。

6、檢測硬盤壞道

磁盤壞道分為邏輯壞道和物理壞道兩種,前者主要由于軟件操作不當造成,可以使用軟件修復;而后者是物理性損壞,只能通過更改磁盤分區(qū)或扇區(qū)占用位置來進行改善,排除掉包含壞塊的磁盤空間。當磁盤出現(xiàn)一下現(xiàn)象時,有可能是磁盤出現(xiàn)壞道,需要進行檢測和修復。

>:讀取磁盤中的數(shù)據(jù)時,磁盤設備發(fā)出異常聲響。

>:訪問磁盤中的某個文件時,反復讀取且出錯,提示文件損壞。

>:對于新建立的分區(qū)無法完成格式化。

>:系統(tǒng)使用該磁盤時頻繁死機。

硬盤出現(xiàn)壞道后,如果不及時更換或進行技術出來,壞道就會越來越多,并可能造成頻繁死機和數(shù)據(jù)丟失的后果。所有必要時應該對磁盤進行定期檢測,檢測是否存在壞道。

在Linux系統(tǒng)中,檢測磁盤的壞道情況可以使用badblocks命令進行,在創(chuàng)建文件系統(tǒng)的過程中也可以結合mkfs命令的選項進行檢測。使用badblocks命令時,“-s”選項用戶顯示進度信息,“-v”選項用于顯示詳情。

eg:使用mkfs命令格式化"/dev/sdb2"分區(qū),并結合"-c"選項進程壞塊檢測。

eg:使用badblocks命令檢測"/dev/sdb2"分區(qū)中是否存心壞塊。

以上為常見問題;歡迎補充~~

標簽:烏蘭察布 防城港 臨沂 撫州 南昌 北海 邢臺 韶關

巨人網(wǎng)絡通訊聲明:本文標題《Linux下軟件包類故障排錯方案詳解》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266