學習啦 > 學習電腦 > 操作系統(tǒng) > Linux教程 > Linux命令查看系統(tǒng)平均負載的方法

Linux命令查看系統(tǒng)平均負載的方法

時間: 志藝942 分享

Linux命令查看系統(tǒng)平均負載的方法

  文章主要介紹了通過Linux命令查看系統(tǒng)平均負載的方法,對于服務器管理員來說非常有用接下來是小編為大家收集的Linux命令查看系統(tǒng)平均負載的方法,歡迎大家閱讀:

  Linux命令查看系統(tǒng)平均負載的方法

  1、Linux系統(tǒng)的平均負載的概念

  有時候我們會覺得系統(tǒng)響應很慢,但是又找不到原因,這時就要查看平均負載了,看它是否有大量的進程在排隊等待。特定時間間隔內運行隊列中的平均進程數(shù)可以反映系統(tǒng)的繁忙程度,所以我們通常會在自己的網(wǎng)站或系統(tǒng)變慢時第一時間查系統(tǒng)的負載,即CPU的平均負載。

  2、查看平均負載

  究竟應該如何查看平均負載呢?最簡單的命令是uptime,如下所示:

  代碼如下:

  [root@localhost ~]# uptime

  11:31:11 up 11 days, 19:01, 2 users, load average: 0.02, 0.01, 0.00

  目前的主流服務器都是雙四核,有相當強悍的CPU,做一般的應用服務的話,Linux系統(tǒng)的負載這塊倒不用我們擔心。

  還可以用w命令來查看,順便可以查看一下系統(tǒng)當前有哪些用戶,他們占用了哪些終端,如下所示:

  代碼如下:

  [root@localhost ~]# w

  11:33:00 up 11 days, 19:03, 2 users, load average: 0.00, 0.00, 0.00

  USER TTY FROM LOGIN@  IDLE  JCPU  PCPU WHAT

  root pts/1113.57.224.3 09:032:11m 0.04s 0.04s -bash

  root pts/2113.57.224.3 11:310.00s 0.02s 0.00s w

  另外,還有動態(tài)命令top,這個命令也可以反映系統(tǒng)負載情況。在下面的命令提示中,我們只關心加粗字體部分。

  代碼如下:

  [root@localhost ~]# top

  top - 11:37:47 up 11 days, 19:08, 2 users, load average: 0.00, 0.00, 0.00

  Tasks: 122 total,  1 running, 121 sleeping,  0 stopped,  0 zombie

  Cpu(s): 0.1%us, 0.0%sy, 0.0%ni, 99.9%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st

  Mem:  4044136k total, 1435504k used, 2608632k free,  274740k buffers

  Swap: 8193140k total,0k used, 8193140k free,  941884k cached

  上面加粗字體顯示的內容是什么意思呢?再通過uptime查看一下。

  代碼如下:

  [root@localhost ~]# uptime

  11:39:36 up 11 days, 19:16, 1 user, load average: 0.09, 0.03, 0.01

  原來它所表示的是過去的1分鐘、5分鐘和15分鐘內進程隊列中的平均進程數(shù)量。

  那么,如何衡量當前系統(tǒng)是否負載過高呢?可以從以下幾點來考慮。

  如果每個CPU(可以按CPU核心的數(shù)量計算)當前的活動進程數(shù)不大于3,則系統(tǒng)性能良好。

  如果每個CPU當前的活動進程數(shù)不大于4,表示可以接受。

  如果每個CPU當前的活動進程數(shù)大于5,則系統(tǒng)性能問題嚴重。

  還可以結合vmstat命令來判斷我們的系統(tǒng)是否過于繁忙,如果確定很繁忙的話,就要考慮是否更換服務器或增加CPU的個數(shù)了??偨Y如下:

  如果r經常大于3或4,且id經常少于50,則表示CPU的負荷很重。

  在上面例子中,我的服務器是PowerEdge 2850,CPU是雙核雙線程的,則0.09/2=0.045(即負載值/真實CPU個數(shù)),此系統(tǒng)的CPU負載基本可以忽略了。事實上,現(xiàn)在主流服務器 的CPU都很強悍,如果不是應用虛擬化等特殊場景,基本上負載都很小。

  按照前面的計算公式,我所配置Nagios報警的CPU負載閾值 為CPU核心的數(shù)量(即CPU的物理個數(shù)×核數(shù))。還是以我的服務器PowerEdge 2850為例,其CPU核心的數(shù)量為2×2=4,則設置報警值為4。這樣設置是合理的,因為畢竟不是每個應用服務器的CPU都支持多核心,畢竟整個網(wǎng)站中 還有些性能比較弱的服務器是用來做備份的。

  
看了“Linux命令查看系統(tǒng)平均負載的方法”還想看:

1.linux如何查看cpu負載

2.Linux常用性能檢測命令

3.Linux怎么查看物理CPU個數(shù)

4.怎么用命令行查看Linux系統(tǒng)位數(shù)

5.uptime詳解,最通俗的說明了cpu平均負載

3029474