<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Shell腳本實現Linux系統和進程資源監控_基礎知識

        來源:懂視網 責編:小采 時間:2020-11-27 21:35:19
        文檔

        Shell腳本實現Linux系統和進程資源監控_基礎知識

        Shell腳本實現Linux系統和進程資源監控_基礎知識:在服務器運維過程中,經常需要對服務器的各種資源進行監控,例如:CPU的負載監控,磁盤的使用率監控,進程數目監控等等,以在系統出現異常時及時報警,通知系統管理員。本文介紹在Linux系統下幾種常見的監控需求及其shell腳本的編寫。 文章目錄: 1.Lin
        推薦度:
        導讀Shell腳本實現Linux系統和進程資源監控_基礎知識:在服務器運維過程中,經常需要對服務器的各種資源進行監控,例如:CPU的負載監控,磁盤的使用率監控,進程數目監控等等,以在系統出現異常時及時報警,通知系統管理員。本文介紹在Linux系統下幾種常見的監控需求及其shell腳本的編寫。 文章目錄: 1.Lin

        在服務器運維過程中,經常需要對服務器的各種資源進行監控,例如:CPU的負載監控,磁盤的使用率監控,進程數目監控等等,以在系統出現異常時及時報警,通知系統管理員。本文介紹在Linux系統下幾種常見的監控需求及其shell腳本的編寫。

        文章目錄:

        1.Linux使用 Shell 檢查進程是否存在
        2.Linux使用 Shell檢測進程 CPU 利用率
        3.Linux使用 Shell檢測進程內存使用量
        4.Linux使用 Shell檢測進程句柄使用量
        5.Linux使用 Shell查看某個 TCP 或 UDP 端口是否在監聽
        6.Linux使用 Shell查看某個進程名正在運行的個數
        7.Linux使用 Shell檢測系統 CPU 負載
        8.Linux使用 Shell檢測系統磁盤空間
        9.總結

        檢查進程是否存在

        在對進程進行監控時,我們一般需要得到該進程的 ID,進程 ID 是進程的唯一標識,但是有時可能在服務器上不同用戶下運行著多個相同進程名的進程,下面的函數 GetPID 給出了獲取指定用戶下指定進程名的進程 ID 功能(目前只考慮這個用戶下啟動一個此進程名的進程),它有兩個參數為用戶名和進程名,它首先使用 ps 查找進程信息,同時通過 grep 過濾出需要的進程,最后通過 sed 和 awk 查找需要進程的 ID 值(此函數可根據實際情況修改,比如需要過濾其它信息等)。

        清單 1. 對進程進行監控

        代碼如下:
        function GetPID #User #Name
        {
        PsUser=$1
        PsName=$2
        pid=`ps -u $PsUser|grep $PsName|grep -v grep|grep -v vi|grep -v dbx\n
        |grep -v tail|grep -v start|grep -v stop |sed -n 1p |awk '{print $1}'`
        echo $pid
        }

        示例演示:

        1)源程序(例如查找用戶為 root,進程名為 CFTestApp 的進程 ID)
        代碼如下:
        PID=`GetPID root CFTestApp`

        echo $PID

        2)結果輸出

        代碼如下:
        11426
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:11426 為 root 用戶下的 CFTestApp 程序的進程 ID。

        4)命令介紹

        1. ps: 查看系統中瞬間進程信息。 參數:-u< 用戶識別碼 > 列出屬于該用戶的程序的狀況,也可使用用戶名稱來指定。 -p< 進程識別碼 > 指定進程識別碼,并列出該進程的狀況。 -o 指定輸出格式 2. grep: 用于查找文件中符合字符串的當前行。 參數:-v 反向選擇,亦即顯示出沒有 ‘搜尋字符串' 內容的那一行。 3. sed: 一個非交互性文本編輯器,它編輯文件或標準輸入導出的文件,一次只能處理一行內容。 參數:-n 讀取下一個輸入行,用下一個命令處理新的行而不是用第一個命令。 p 標志 打印匹配行 4. awk:一種編程語言,用于在 linux/unix 下對文本和數據進行處理。數據可以來自標準輸入、一個或多個文件,或其它命令的輸出。它支持用戶自定義函數和動態正則表達式等先進功能,是 linux/unix 下的一個強大編程工具。它在命令行中使用,但更多是作為腳本來使用。awk 的處理文本和數據的方式:它逐行掃描文件,從第一行到最后一行,尋找匹配的特定模式的行,并在這些行上進行你想要的操作。如果沒有指定處理動作,則把匹配的行顯示到標準輸出 ( 屏幕 ),如果沒有指定模式,則所有被操作所指定的行都被處理。 參數:-F fs or –field-separator fs :指定輸入文件折分隔符,fs 是一個字符串或者是一個正則表達式,如 -F:。
        有時有可能進程沒有啟動,下面的功能是檢查進程 ID 是否存在,如果此進程沒有運行輸出:
        代碼如下:
        The process does not exist.
        # 檢查進程是否存在
        if [ "-$PID" == "-" ]
        then
        {
        echo "The process does not exist."
        }
        fi

        檢測進程 CPU 利用率

        在對應用服務進行維護時,我們經常遇到由于 CPU 過高導致業務阻塞,造成業務中斷的情況。CPU 過高可能由于業務量過負荷或者出現死循環等異常情況,通過腳本對業務進程 CPU 進行時時監控,可以在 CPU 利用率異常時及時通知維護人員,便于維護人員及時分析,定位,以及避免業務中斷等。下面的函數可獲得指定進程 ID 的進程 CPU 利用率。它有一個參數為進程 ID,它首先使用 ps 查找進程信息,同時通過 grep -v 過濾掉 %CPU 行,最后通過 awk 查找 CPU 利用百分比的整數部分(如果系統中有多個 CPU,CPU 利用率可以超過 100%)。

        清單 2. 對業務進程 CPU 進行實時監控

        代碼如下:
        function GetCpu
        {
        CpuValue=`ps -p $1 -o pcpu |grep -v CPU | awk '{print $1}' | awk - F. '{print $1}'`
        echo $CpuValue
        }

        下面的功能是通過上面的函數 GetCpu 獲得此進程的 CPU 利用率,然后通過條件語句判斷 CPU 利用率是否超過限制,如果超過 80%(可以根據實際情況進行調整),則輸出告警,否則輸出正常信息。

        清單 3. 判斷 CPU 利用率是否超過限制

        代碼如下:
        function CheckCpu
        {
        PID=$1
        cpu=`GetCpu $PID`
        if [ $cpu -gt 80 ]
        then
        {
        echo “The usage of cpu is larger than 80%”
        }
        else
        {
        echo “The usage of cpu is normal”
        }
        fi
        }

        示例演示:

        1)源程序(假設上面已經查詢出 CFTestApp 的進程 ID 為 11426)
        代碼如下:
        CheckCpu 11426

        2)結果輸出
        代碼如下:
        The usage of cpu is 75
        The usage of cpu is normal
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:CFTestApp 程序當前的 CPU 使用為 75%,是正常的,沒有超過 80% 的告警限制。

        檢測進程內存使用量

        在對應用服務進行維護時,也經常遇到由于內存使用過大導致進程崩潰,造成業務中斷的情況(例如 32 位程序可尋址的最大內存空間為 4G,如果超出將申請內存失敗,同時物理內存也是有限的)。內存使用過高可能由于內存泄露,消息堆積等情況,通過腳本對業務進程內存使用量進行時時監控,可以在內存使用量異常時及時發送告警(例如通過短信),便于維護人員及時處理。下面的函數可獲得指定進程 ID 的進程內存使用情況。它有一個參數為進程 ID,它首先使用 ps 查找進程信息,同時通過 grep -v 過濾掉 VSZ 行 , 然后通過除 1000 取以兆為單位的內存使用量。

        清單 4. 對業務進程內存使用量進行監控

        代碼如下:
        function GetMem
        {
        MEMUsage=`ps -o vsz -p $1|grep -v VSZ`
        (( MEMUsage /= 1000))
        echo $MEMUsage
        }

        下面的功能是通過上面的函數 GetMem獲得此進程的內存使用,然后通過條件語句判斷內存使用是否超過限制,如果超過 1.6G(可以根據實際情況進行調整),則輸出告警,否則輸出正常信息。

        清單 5. 判斷內存使用是否超過限制
        代碼如下:
        mem=`GetMem $PID`
        if [ $mem -gt 1600 ]
        then
        {
        echo “The usage of memory is larger than 1.6G”
        }
        else
        {
        echo “The usage of memory is normal”
        }
        fi

        示例演示:

        1)源程序(假設上面已經查詢出 CFTestApp 的進程 ID 為 11426)
        代碼如下:
        mem=`GetMem 11426`

        echo "The usage of memory is $mem M"

        if [ $mem -gt 1600 ]
        then
        {
        echo "The usage of memory is larger than 1.6G"
        }
        else
        {
        echo "The usage of memory is normal"
        }
        fi

        2)結果輸出

        代碼如下:
        The usage of memory is 248 M
        The usage of memory is normal
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:CFTestApp 程序當前的內存使用為 248M,是正常的,沒有超過 1.6G 的告警限制。

        檢測進程句柄使用量

        在對應用服務進行維護時,也經常遇到由于句柄使用 過量導致業務中斷的情況。每個平臺對進程的句柄使用都是有限的,例如在 Linux 平臺,我們可以使用 ulimit – n 命令(open files (-n) 1024)或者對 /etc/security/limits.conf 的內容進行查看,得到進程句柄限制。句柄使用過高可能由于負載過高,句柄泄露等情況,通過腳本對業務進程句柄使用量進行時時監控,可以在異常時及時發送告警(例如通過短信),便于維護人員及時處理。下面的函數可獲得指定進程 ID 的進程句柄使用情況。它有一個參數為進程 ID,它首先使用 ls 輸出進程句柄信息,然后通過 wc -l 統計輸出句柄個數。

        代碼如下:
        function GetDes
        {
        DES=`ls /proc/$1/fd | wc -l`
        echo $DES
        }

        下面功能是通過上面的函數 GetDes獲得此進程的句柄使用量,然后通過條件語句判斷句柄使用是否超過限制,如果超過 900(可以根據實際情況進行調整)個,則輸出告警,否則輸出正常信息。
        代碼如下:
        des=` GetDes $PID`
        if [ $des -gt 900 ]
        then
        {
        echo “The number of des is larger than 900”
        }
        else
        {
        echo “The number of des is normal”
        }
        fi

        示例演示:

        1)源程序(假設上面查詢出 CFTestApp 的進程 ID 為 11426)
        代碼如下:
        des=`GetDes 11426`

        echo "The number of des is $des"

        if [ $des -gt 900 ]
        then
        {
        echo "The number of des is larger than 900"
        }
        else
        {
        echo "The number of des is normal"
        }
        fi

        2)結果輸出

        代碼如下:
        The number of des is 528
        The number of des is normal
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:CFTestApp 程序當前的句柄使用為 528 個,是正常的,沒有超過 900 個的告警限制。

        4)命令介紹

        wc: 統計指定文件中的字節數、字數、行數 , 并將統計結果顯示輸出。 參數:-l 統計行數。 -c 統計字節數。 -w 統計字數。

        查看某個 TCP 或 UDP 端口是否在監聽

        端口檢測是系統資源檢測經常遇到的,特別是在網絡通訊情況下,端口狀態的檢測往往是很重要的。有時可能進程,CPU,內存等處于正常狀態,但是端口處于異常狀態,業務也是沒有正常運行。下面函數可判斷指定端口是否在監聽。它有一個參數為待檢測端口,它首先使用 netstat 輸出端口占用信息,然后通過 grep, awk,wc 過濾輸出監聽 TCP 端口的個數,第二條語句為輸出 UDP 端口的監聽個數,如果 TCP 與 UDP 端口監聽都為 0,返回 0,否則返回 1.

        清單 6. 端口檢測

        代碼如下:
        function Listening
        {
        TCPListeningnum=`netstat -an | grep ":$1 " | \n
        awk '$1 == "tcp" && $NF == "LISTEN" {print $0}' | wc -l`
        UDPListeningnum=`netstat -an|grep ":$1 " \n
        |awk '$1 == "udp" && $NF == "0.0.0.0:*" {print $0}' | wc -l`
        (( Listeningnum = TCPListeningnum + UDPListeningnum ))
        if [ $Listeningnum == 0 ]
        then
        {
        echo "0"
        }
        else
        {
        echo "1"
        }
        fi
        }

        示例演示:

        1)源程序(例如查詢 8080 端口的狀態是否在監聽)


        代碼如下:
        isListen=`Listening 8080`
        if [ $isListen -eq 1 ]
        then
        {
        echo "The port is listening"
        }
        else
        {
        echo "The port is not listening"
        }
        fi

        2)結果輸出

        代碼如下:
        The port is listening
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:這個 Linux 服務器的 8080 端口處在監聽狀態。

        4)命令介紹

        netstat: 用于顯示與 IP、TCP、UDP 和 ICMP 協議相關的統計數據,一般用于檢驗本機各端口的網絡連接情況。 參數:-a 顯示所有連線中的 Socket。 -n 直接使用 IP 地址,而不通過域名服務器。
        下面的功能也是檢測某個 TCP 或者 UDP 端口是否處在正常狀態。

        代碼如下:
        tcp: netstat -an|egrep $1 |awk '$6 == "LISTEN" && $1 == "tcp" {print $0}'
        udp: netstat -an|egrep $1 |awk '$1 == "udp" && $5 == "0.0.0.0:*" {print $0}'

        命令介紹

        egrep: 在文件內查找指定的字符串。egrep 執行效果如 grep -E,使用的語法及參數可參照 grep 指令,與 grep 不同點在于解讀字符串的方法,egrep 是用擴展的正則表達式語法來解讀,而 grep 則用基本的正則表達式語法,擴展的正則表達式比基本的正則表達式有更完整的表達規范。

        查看某個進程名正在運行的個數

        有時我們可能需要得到服務器上某個進程的啟動個數,下面的功能是檢測某個進程正在運行的個數,例如進程名為 CFTestApp。
        代碼如下:
        Runnum=`ps -ef | grep -v vi | grep -v tail | grep "[ /]CFTestApp" | grep -v grep | wc -l

        檢測系統 CPU 負載

        在對服務器進行維護時,有時也遇到由于系統 CPU(利用率)負載 過量導致業務中斷的情況。服務器上可能運行多個進程,查看單個進程的 CPU 都是正常的,但是整個系統的 CPU 負載可能是異常的。通過腳本對系統 CPU 負載進行時時監控,可以在異常時及時發送告警,便于維護人員及時處理,預防事故發生。下面的函數可以檢測系統 CPU 使用情況 . 使用 vmstat 取 5 次系統 CPU 的 idle 值,取平均值,然后通過與 100 取差得到當前 CPU 的實際占用值。

        代碼如下:
        function GetSysCPU
        {
        CpuIdle=`vmstat 1 5 |sed -n '3,$p' \n
        |awk '{x = x + $15} END {print x/5}' |awk -F. '{print $1}'
        CpuNum=`echo "100-$CpuIdle" | bc`
        echo $CpuNum
        }

        示例演示:

        1)源程序

        代碼如下:
        cpu=`GetSysCPU`

        echo "The system CPU is $cpu"

        if [ $cpu -gt 90 ]
        then
        {
        echo "The usage of system cpu is larger than 90%"
        }
        else
        {
        echo "The usage of system cpu is normal"
        }
        fi

        2)結果輸出
        代碼如下:
        The system CPU is 87
        The usage of system cpu is normal
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:當前 Linux 服務器系統 CPU 利用率為 87%,是正常的,沒有超過 90% 的告警限制。

        4)命令介紹

        vmstat:Virtual Meomory Statistics(虛擬內存統計)的縮寫,可對操作系統的虛擬內存、進程、CPU 活動進行監視。
        參數: -n 表示在周期性循環輸出時,輸出的頭部信息僅顯示一次。

        檢測系統磁盤空間

        系統磁盤空間檢測是系統資源檢測的重要部分,在系統維護維護中,我們經常需要查看服務器磁盤空間使用情況。因為有些業務要時時寫話單,日志,或者臨時文件等,如果磁盤空間用盡,也可能會導致業務中斷,下面的函數可以檢測當前系統磁盤空間中某個目錄的磁盤空間使用情況 . 輸入參數為需要檢測的目錄名,使用 df 輸出系統磁盤空間使用信息,然后通過 grep 和 awk 過濾得到某個目錄的磁盤空間使用百分比。

        代碼如下:
        function GetDiskSpc
        {
        if [ $# -ne 1 ]
        then
        return 1
        fi

        Folder="$1$"
        DiskSpace=`df -k |grep $Folder |awk '{print $5}' |awk -F% '{print $1}'
        echo $DiskSpace
        }

        示例演示:

        1)源程序(檢測目錄為 /boot)


        代碼如下:
        Folder="/boot"

        DiskSpace=`GetDiskSpc $Folder`

        echo "The system $Folder disk space is $DiskSpace%"

        if [ $DiskSpace -gt 90 ]
        then
        {
        echo "The usage of system disk($Folder) is larger than 90%"
        }
        else
        {
        echo "The usage of system disk($Folder) is normal"
        }
        fi

        2)結果輸出

        代碼如下:
        The system /boot disk space is 14%
        The usage of system disk(/boot) is normal
        [dyu@xilinuxbldsrv shell]$

        3)結果分析

        從上面的輸出可見:當前此 Linux 服務器系統上 /boot 目錄的磁盤空間已經使用了 14%,是正常的,沒有超過使用 90% 的告警限制。

        4)命令介紹

        df:檢查文件系統的磁盤空間占用情況。可以利用該命令來獲取硬盤被占用了多少空間,目前還剩下多少空間等信息。 參數:-k 以 k 字節為單位顯示。

        總結

        在 Linux 平臺下,shell 腳本監控是一個非常簡單,方便,有效的對服務器,進程進行監控的方法,對系統開發以及進程維護人員非常有幫助。它不僅可以對上面的信息進行監控,發送告警,同時也可以監控進程的日志等等的信息,希望本文對大家有幫助。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Shell腳本實現Linux系統和進程資源監控_基礎知識

        Shell腳本實現Linux系統和進程資源監控_基礎知識:在服務器運維過程中,經常需要對服務器的各種資源進行監控,例如:CPU的負載監控,磁盤的使用率監控,進程數目監控等等,以在系統出現異常時及時報警,通知系統管理員。本文介紹在Linux系統下幾種常見的監控需求及其shell腳本的編寫。 文章目錄: 1.Lin
        推薦度:
        標簽: 監控 系統 linux
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 全免费a级毛片免费看不卡 | 亚洲成人一区二区| 亚洲免费视频网站| 国产无限免费观看黄网站| 日韩中文字幕免费| 亚洲国产品综合人成综合网站| 大地资源中文在线观看免费版| 中文字幕第13亚洲另类| 色屁屁www影院免费观看视频| 天天看片天天爽_免费播放| 亚洲人成片在线观看| 蜜臀98精品国产免费观看| 亚洲男人天堂2017| 桃子视频在线观看高清免费视频 | 久久久久亚洲精品男人的天堂| 亚洲av无码一区二区三区在线播放 | 日韩免费电影网址| 国产偷v国产偷v亚洲高清| a级成人毛片免费视频高清| 亚洲午夜国产精品无码老牛影视| 色多多A级毛片免费看| 亚洲av午夜精品一区二区三区 | 天天天欲色欲色WWW免费| 亚洲色大成网站www尤物| 毛片a级毛片免费播放下载| 亚洲人配人种jizz| 免费无码AV片在线观看软件| 波多野结衣亚洲一级| 性色av免费观看| 羞羞视频免费网站入口| 亚洲一级Av无码毛片久久精品| 中文字幕无码免费久久9一区9 | 成人无码区免费A∨直播| 国产亚洲午夜高清国产拍精品| 好男人资源在线WWW免费| 亚洲gv猛男gv无码男同短文| 无码av免费一区二区三区| 亚洲中文久久精品无码1| 午夜私人影院免费体验区| 国产亚洲日韩在线a不卡| 亚洲日本一区二区三区在线|