新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 監(jiān)視Linux系統(tǒng)資源的使用情況

監(jiān)視Linux系統(tǒng)資源的使用情況

作者: 時(shí)間:2009-06-25 來源:網(wǎng)絡(luò) 收藏
雖然說操作系統(tǒng)要比Windows操作系統(tǒng)穩(wěn)定的多。但是這個(gè)穩(wěn)定是相對(duì)而言的。也就是說,操作系統(tǒng)也會(huì)有鬧脾氣的時(shí)候。在某些情況下,其系統(tǒng)的資源使用率(包括CPU或者內(nèi)存),也會(huì)達(dá)到90%以上甚至更多。為此系統(tǒng)管理員在必要的時(shí)候,仍然需要監(jiān)視的使用情況。筆者今天就給大家介紹一下,在操作系統(tǒng)下如何監(jiān)視這個(gè),做到心中有數(shù)。

一、如何監(jiān)視?

在Windows操作系統(tǒng)中,可以通過任務(wù)管理器來查詢各個(gè)進(jìn)程所占用的CPU與內(nèi)存的比率。在Linux操作系統(tǒng)中沒有這種圖形化的管理。在命令行模式下,鍵入top命令,即可以看到各個(gè)進(jìn)程所占用的系統(tǒng)資源。

作為一個(gè)合格的系統(tǒng)管理員,出于系統(tǒng)性能優(yōu)化或者其他方面的考慮,往往需要掌握系統(tǒng)中最消耗CPU或者內(nèi)存資源的程序。為了達(dá)到這個(gè)目的,系統(tǒng)管理員就需要借助系統(tǒng)提供的top命令。這個(gè)命令可以幫助管理員監(jiān)控系統(tǒng)資源的使用情況,包括內(nèi)存、CPU、交換文件分區(qū)的使用率等等。如上圖所示,就是這個(gè)命令的執(zhí)行結(jié)果。系統(tǒng)管理員想要提升操作系統(tǒng)的性能,第一步就是需要讀懂上面這張表格。如果這種圖中的內(nèi)容系統(tǒng)管理員無法看懂,那么他就想提升系統(tǒng)的性能根本無法入手。

Top命令的運(yùn)行結(jié)果大致可以分為兩個(gè)部分。上半部是使一些統(tǒng)計(jì)的信息,包括內(nèi)存和交換分區(qū)的使用情況、CPU的運(yùn)行情況、進(jìn)程的總數(shù)等等。在這些統(tǒng)計(jì)信息中,系統(tǒng)管理員除了要關(guān)注這些重要資源的使用濾外,還需要注意進(jìn)程運(yùn)行的狀態(tài)。如上圖所示,可見在Linux系統(tǒng)中進(jìn)程的狀態(tài)主要有四種,分別為running、sleeping、stopped和zombie。如果從系統(tǒng)維護(hù)與性能優(yōu)化考慮,則系統(tǒng)管理員需要關(guān)注那些狀態(tài)為zombie的進(jìn)程。若進(jìn)程處于這個(gè)狀態(tài),在Linux操作系統(tǒng)中叫做僵尸進(jìn)程。什么叫做僵尸進(jìn)程呢?就是那些父進(jìn)程還沒死、但是子進(jìn)程卻死了的進(jìn)程。在Linux操作系統(tǒng)中,進(jìn)程一般分為父進(jìn)程和子進(jìn)程。某個(gè)進(jìn)程A可能會(huì)調(diào)用另外一個(gè)進(jìn)程B。此時(shí)這個(gè)進(jìn)程A就叫做父進(jìn)程,而進(jìn)程B就叫做子進(jìn)程。由于一些意外的情況,子進(jìn)程運(yùn)行已經(jīng)停止,但是父進(jìn)程卻還不知道子進(jìn)程早已停止運(yùn)行,還在那邊傻傻的等待著子進(jìn)程返回運(yùn)行結(jié)果。由于子進(jìn)程沒有返回結(jié)果,則父進(jìn)程可能一直會(huì)在那邊等待。從而導(dǎo)致系統(tǒng)性能的下降。如果系統(tǒng)管理員發(fā)現(xiàn)有僵尸進(jìn)程的話,首先要做的就是結(jié)束父進(jìn)程(有時(shí)候還需要查看這個(gè)父進(jìn)程打開的其他子進(jìn)程運(yùn)行情況),以釋放其占用的系統(tǒng)資源。其次如果這種情況發(fā)生的比較頻繁時(shí),則系統(tǒng)管理員就需要分析到底是什么原因?qū)е逻@種情況發(fā)生的。找到原因后要采取積極的措施。通常情況下,如果子進(jìn)程的狀態(tài)為“僵尸”時(shí),父進(jìn)程就不會(huì)自動(dòng)結(jié)束,從而其占用的系統(tǒng)資源就不會(huì)自動(dòng)釋放,從而降低操作系統(tǒng)的性能。

二、Top命令的使用技巧。

1、 選擇合適的排序順序

在Windows操作系統(tǒng)的任務(wù)管理器中,管理員可以根據(jù)需要選擇合適的排序順序,如按CPU排序或者按內(nèi)存的使用率進(jìn)行排序。而在top命令的顯示結(jié)果中,默認(rèn)情況下是按照CPU的使用率來進(jìn)行排序的。如果現(xiàn)在系統(tǒng)管理員想按照內(nèi)存使用率來排序,該如何處理呢?如果要想改變top命令結(jié)果的排序順序,則可以按m鍵來按內(nèi)存進(jìn)行排序。注意這里的m是小寫,而不是大寫的。在Linux操作系統(tǒng)中大部分命令與參數(shù)大小寫都是敏感的。這跟微軟操作系統(tǒng)中的DOS命令不同。Dos命令是不區(qū)分大小寫的。雖然這個(gè)排序沒有像微軟操作系統(tǒng)中的任務(wù)管理器那么方便,只需要點(diǎn)點(diǎn)鼠標(biāo)就可以完成排序。但是只要熟悉相關(guān)的命令,在命令行中對(duì)其排序沒有大家想想的那么困難。

2、 監(jiān)視特定用戶使用的資源情況。

  在Windows操作系統(tǒng)中,如果想要查看特定帳戶所打開的進(jìn)程以及所耗用的系統(tǒng)資源,操作非常簡(jiǎn)單。只需要打開系統(tǒng)任務(wù)管理器,然后按照用戶來進(jìn)行排序。就可以知道某個(gè)用戶開啟了哪些進(jìn)程以及所占用的比例。而在top命令中,沒有按帳戶進(jìn)行排序的功能。即在上面這個(gè)顯示結(jié)果中,只可以按照內(nèi)存使用率或者CPU負(fù)載來進(jìn)行排序,而無法按照用戶來進(jìn)行排序。如上圖所示,在同一個(gè)結(jié)果中夾雜著系統(tǒng)特權(quán)用戶root與普通用戶所打開的進(jìn)程。這對(duì)于系統(tǒng)管理員查找問題原因非常的不方便。有時(shí)候系統(tǒng)管理員往往需要只查看特定用戶的進(jìn)程,如只需要查看oracle帳戶所打開的進(jìn)程以及所占用的系統(tǒng)資源。而忽略掉系統(tǒng)帳戶。因?yàn)樘貦?quán)帳戶其他用戶無權(quán)進(jìn)行登陸操作,而其運(yùn)行的往往是一些系統(tǒng)級(jí)別的進(jìn)程,為此一般不會(huì)出現(xiàn)問題。而普通用戶可以運(yùn)行一些應(yīng)用程序。有時(shí)候他們糊里糊涂可能會(huì)打開一些非法程序,占用大量的系統(tǒng)資源,從而降低系統(tǒng)性能。廢話少說,如何才能夠查看特定帳戶所啟動(dòng)的進(jìn)程呢?其實(shí)很簡(jiǎn)單?,F(xiàn)運(yùn)行top命令,讓系統(tǒng)統(tǒng)計(jì)所有帳戶的進(jìn)程。然后在需要查看特定帳戶的進(jìn)程使,只需要按u鍵(注意小寫),然后輸入用戶名即可。此時(shí)系統(tǒng)會(huì)自動(dòng)把其他帳戶的進(jìn)程過濾掉,方便系統(tǒng)管理員查看。按用戶過濾后,仍然可以按m鍵來對(duì)現(xiàn)實(shí)的結(jié)果進(jìn)行過濾。如果在一開始就需要查看某個(gè)特定用戶的進(jìn)程,那么只需要直接在top命令后面加入-u可選項(xiàng)然后帶上具體的用戶名即可。但是,此時(shí)如果再想查看全部用戶的話,那么只有先推出top命令,然后再利用top命令不帶任何選項(xiàng),來查看所有用戶的進(jìn)程?;蛘哒f,再在這個(gè)窗口中輸入字符u,然后直接按回車鍵,也可以顯示所用用戶的進(jìn)程信息。

3、動(dòng)態(tài)統(tǒng)計(jì)信息。

使用top命令來統(tǒng)計(jì)進(jìn)程的運(yùn)行信息,跟微軟操作系統(tǒng)的任務(wù)管理器一樣,都是動(dòng)態(tài)調(diào)整的。也就是說,系統(tǒng)會(huì)每隔一段時(shí)間去統(tǒng)計(jì)這個(gè)信息,然后動(dòng)態(tài)的顯示在窗口中。不需要用戶手工去更新相關(guān)的信息。而且從上面的圖形中可以看出,top命令統(tǒng)計(jì)的信息要比微軟任務(wù)管理器統(tǒng)計(jì)的信息要多的多。所以對(duì)系統(tǒng)管理員來說,具有更大的參考價(jià)值。筆者以前也很喜歡采用微軟操作系統(tǒng)的任務(wù)管理器。而了解了top命令后,就對(duì)其鐘愛有加了。因?yàn)槠洳粌H可以完成任務(wù)管理器中的所有功能。而且top命令中有的信息在微軟任務(wù)管理器中卻無法顯示。而這些信息往往對(duì)我們維護(hù)系統(tǒng)、提升性能具有很大的參考價(jià)值。

4、刪除有異常的進(jìn)程。

如果這個(gè)窗口中,發(fā)現(xiàn)某些進(jìn)程有異常或者用戶執(zhí)行了規(guī)定以外的應(yīng)用程序,如占用了太多的系統(tǒng)資源或者有僵尸進(jìn)程的存在,則可以直接在這個(gè)窗口中講其刪除。操作的方法很簡(jiǎn)單,只需要在這個(gè)窗口內(nèi)輸入字符p,然后系統(tǒng)會(huì)提示系統(tǒng)管理員輸入要關(guān)閉進(jìn)程的PID。管理員只需要鍵入這個(gè)值,然后按回車鍵就可以殺掉不需要的進(jìn)程。不過在關(guān)閉進(jìn)程的時(shí)候,有權(quán)限的限制。系統(tǒng)特權(quán)帳戶root可以關(guān)閉所有用戶的進(jìn)程。而普通帳戶則只能夠刪除自己打開的程序,而無法關(guān)閉其他用戶的進(jìn)程。如現(xiàn)在系統(tǒng)管理員先以oracle用戶登錄,發(fā)現(xiàn)root帳戶下某個(gè)進(jìn)程異常,想要關(guān)閉時(shí),系統(tǒng)會(huì)提示無法關(guān)閉的錯(cuò)誤信息。此時(shí)管理員必須先終止這個(gè)top進(jìn)程,然后利用su命令更改登陸的帳戶。然后再關(guān)閉這個(gè)異常的進(jìn)程。系統(tǒng)管理員可以同時(shí)關(guān)閉多個(gè)進(jìn)程。方法很簡(jiǎn)單,就是同時(shí)輸入多個(gè)需要關(guān)閉的進(jìn)程號(hào)。在各個(gè)進(jìn)程號(hào)之間需要利用逗號(hào)隔開。

top在系統(tǒng)維護(hù)中是一個(gè)很有用的命令。除了可以實(shí)現(xiàn)如上的功能外,還可以設(shè)置其動(dòng)態(tài)更新的時(shí)間間隔等等。不過需要注意的是,在不同版本的Linux系統(tǒng)中其功能稍有差異,而且其顯示的布局與內(nèi)容也有所不同。為此當(dāng)系統(tǒng)管理員維護(hù)其不怎么熟悉的版本時(shí),有時(shí)候需要查看系統(tǒng)的幫助說明。此時(shí)只需要在top命令后面加上?號(hào)就可以獲得相關(guān)的幫助。這個(gè)聯(lián)機(jī)幫助文檔根top命令一樣,都是系統(tǒng)管理員的好幫手。不過可惜的是,現(xiàn)在這些在線幫助文檔都是英文的。所以這對(duì)系統(tǒng)管理員的英文說明要求比較高。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


關(guān)鍵詞: 系統(tǒng)資源 Linux

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉