如何查看服务器当前的负载信息
生活随笔
收集整理的這篇文章主要介紹了
如何查看服务器当前的负载信息
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
From: http://blog.csdn.net/mal327/article/details/7423750
?
如何查看服務(wù)器當前的負載信息http://www.flybaaa.com/help/69_1.html
網(wǎng)吧內(nèi)突然很卡,這個情況我相信大家都有遇見過,但是通過什么方法來排查是否linux服務(wù)器的負載過大導(dǎo)致的這個問題呢?
我們提供了以下三個方法:
方法一:
通過top命令來查看服務(wù)器負載
? ? ? ? 在對此Linux服務(wù)器性能分析之前,先了解下Linux系統(tǒng)Load average負載的知識,負載均值在 uptime 或者 top 命令中可以看到,它們可能會顯示成這個樣子:
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?load average: 0.15, 0.14, 0.11
? ? ? ? 很多人會這樣理解負載均值:三個數(shù)分別代表不同時間段的系統(tǒng)平均負載(一分鐘、五 分鐘、以及十五分鐘),它們的數(shù)字當然是越小越好。
數(shù)字越高,說明服務(wù)器的負載越大,這也可能是服務(wù)器出現(xiàn)某種問題的信號。
一個單核的處理器可以形象得比喻成一條單車道。如果前面沒有車輛在等待,那么你可以告訴后面的司機通過。 如果車輛眾多,那么需要告知他們可能需要稍等一會。
因此,需要些特定的代號表示目前的車流情況,例如:
0.00 表示目前橋面上沒有任何的車流。 實際上這種情況與 0.00 和 1.00 之間是相同的,總而言之很通暢,過往的車輛可以絲毫不用等待的通過。
1.00 表示剛好是在這座橋的承受范圍內(nèi)。 這種情況不算糟糕,只是車流會有些堵,不過這種情況可能會造成交通越來越慢。
超過 1.00,那么說明這座橋已經(jīng)超出負荷,交通嚴重的擁堵。那么情況有多糟糕?例如 2.00 的情況說明車流已經(jīng)超出了橋所能承受的一倍,那么將有多余過橋一倍的車輛正在焦急的等待。3.00 的話情況就更不妙了,說明這座橋基本上已經(jīng)快承受不了,還有超出橋負載兩倍多的車輛正在等待。
? ? ? ? 上面的情況和處理器的負載情況非常相似。一輛汽車的過橋時間就好比是處理器處理某線程的實際時間。Unix 系統(tǒng)定義的進程運行時長為所有處理器內(nèi)核的處理時間加上線程在隊列中等待的時間。和收過橋費的管理員一樣,你當然希望你的汽車(操作)不會被焦急的等待。所以,理想狀態(tài)下,都希望負載平均值小于 1.00 。當然不排除部分峰值會超過 1.00,但長此以往保持這 個狀態(tài),就說明會有問題,這時候你應(yīng)該會很焦急。
? ? ? ? “所以你說的理想負荷為 1.00 ?”
? ? ? ? 嗯,這種情況其實并不完全正確。負荷 1.00 說明系統(tǒng)已經(jīng)沒有剩余的資源了。在實際情況中 ,有經(jīng)驗的系統(tǒng)管理員都會將這條線劃在 0.70:
? ? ? ?“需要進行調(diào)查法則”: 如果長期你的系統(tǒng)負載在 0.70 上下,那么你需要在事情變得更糟糕之前,花些時間了解其原因。
? ? ? ?“現(xiàn)在就要修復(fù)法則”:1.00 。 如果你的服務(wù)器系統(tǒng)負載長期徘徊于 1.00,那么就應(yīng)該馬上解決這個問題。否則,你將半夜接到你上司的電話,這可不是件令人愉快的事情。
? ? ? ?“凌晨三點半鍛煉身體法則”:5.00。 如果你的服務(wù)器負載超過了 5.00 這個數(shù)字,那么你將失去你的睡眠,還得在會議中說明這情況發(fā)生的原因,總之千萬不要讓它發(fā)生。
? ? ? ? 那么多個處理器呢?我的均值是 3.00,但是系統(tǒng)運行正常!哇喔,你有四個處理器的主機?那么它的負載均值在 3.00 是很正常的。在多處理器系統(tǒng)中,負載均值是基于內(nèi)核的數(shù)量決定的。以 100% 負載計算,1.00 表示單個處理器,而 2.00 則說明有兩個雙處理器,那么 4.00 就說明主機具有四個處理器。
回到我們上面有關(guān)車輛過橋的比喻。1.00 我說過是“一條單車道的道路”。那么在單車道 1.00 情況中,說明這橋梁已經(jīng)被車塞滿了。而在雙處理器系統(tǒng)中,這意味著多出了一倍的 負載,也就是說還有 50% 的剩余系統(tǒng)資源 - 因為還有另外條車道可以通行。
所以,單處理器已經(jīng)在負載的情況下,雙處理器的負載滿額的情況是 2.00,它還有一倍的資源可以利用。
? ? ? ? ?從上圖的top命令可以了解到,Linux服務(wù)器運行了5天23小時20分,在load average的數(shù)據(jù)來看,這臺快吧Linux無盤服務(wù)器可以說是壓力為零,運行十分流暢。
輸入 iostat -x -k -t
? ? ? ? ?說明:%util: 一秒中有百分之多少的時間用于 I/O 操作,或者說一秒中有多少時間 I/O 隊列是非空的。
? ? ? ? ?即 delta(use)/s/1000 (因為use的單位為毫秒)
? ? ? ? ?如果 %util 接近 100%,說明產(chǎn)生的I/O請求太多,I/O系統(tǒng)已經(jīng)滿負荷,該磁盤可能存在瓶頸。
? ? ? ? 如果玩游戲很卡,可以用hdparm –t /dev/磁盤名稱來測試磁盤性能是否達標,下圖是單個希捷1T的盤測試的結(jié)果
? ? ? ? 說明:sd表示硬盤是SATA,SCSI或者SAS,a表示串口的第一塊硬盤
總結(jié)
以上是生活随笔為你收集整理的如何查看服务器当前的负载信息的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 对话Linus:Linux 25岁啦
- 下一篇: SpringBoot(六):Spring