獲取 linux 系統 CPU、內存、磁盤 IO 等信息的腳本


獲取 linux 系統 CPU、內存、磁盤 IO 等信息的腳本

1. 腳本

[root@centos7 ~]# cat yikou.sh 
#!/bin/bash
# 獲取要監控的本地服務器IP地址
IP=`ifconfig | grep inet | grep -vE 'inet6|127.0.0.1' | awk '{print $2}'`
echo "IP地址:"$IP
 
# 獲取cpu總核數
cpu_num=`grep -c "model name" /proc/cpuinfo`
echo "cpu總核數:"$cpu_num
 
# 1、獲取CPU利用率
################################################
#us 用戶空間占用CPU百分比
#sy 內核空間占用CPU百分比
#ni 用戶進程空間內改變過優先級的進程占用CPU百分比
#id 空閑CPU百分比
#wa 等待輸入輸出的CPU時間百分比
#hi 硬件中斷
#si 軟件中斷
#################################################
# 獲取用戶空間占用CPU百分比
cpu_user=`top -b -n 1 | grep Cpu | awk '{print $2}' | cut -f 1 -d "%"`
echo "用戶空間占用CPU百分比:"$cpu_user
 
# 獲取內核空間占用CPU百分比
cpu_system=`top -b -n 1 | grep Cpu | awk '{print $4}' | cut -f 1 -d "%"`
echo "內核空間占用CPU百分比:"$cpu_system
 
# 獲取空閑CPU百分比
cpu_idle=`top -b -n 1 | grep Cpu | awk '{print $8}' | cut -f 1 -d "%"`
echo "空閑CPU百分比:"$cpu_idle
 
# 獲取等待輸入輸出占CPU百分比
cpu_iowait=`top -b -n 1 | grep Cpu | awk '{print $10}' | cut -f 1 -d "%"`
echo "等待輸入輸出占CPU百分比:"$cpu_iowait
 
#2、獲取CPU上下文切換和中斷次數
# 獲取CPU中斷次數
cpu_interrupt=`vmstat -n 1 1 | sed -n 3p | awk '{print $11}'`
echo "CPU中斷次數:"$cpu_interrupt
 
# 獲取CPU上下文切換次數
cpu_context_switch=`vmstat -n 1 1 | sed -n 3p | awk '{print $12}'`
echo "CPU上下文切換次數:"$cpu_context_switch
 
#3、獲取CPU負載信息
# 獲取CPU15分鍾前到現在的負載平均值
cpu_load_15min=`uptime | awk '{print $11}' | cut -f 1 -d ','`
echo "CPU 15分鍾前到現在的負載平均值:"$cpu_load_15min
 
# 獲取CPU5分鍾前到現在的負載平均值
cpu_load_5min=`uptime | awk '{print $10}' | cut -f 1 -d ','`
echo "CPU 5分鍾前到現在的負載平均值:"$cpu_load_5min
 
# 獲取CPU1分鍾前到現在的負載平均值
cpu_load_1min=`uptime | awk '{print $9}' | cut -f 1 -d ','`
echo "CPU 1分鍾前到現在的負載平均值:"$cpu_load_1min
 
# 獲取任務隊列(就緒狀態等待的進程數)
cpu_task_length=`vmstat -n 1 1 | sed -n 3p | awk '{print $1}'`
echo "CPU任務隊列長度:"$cpu_task_length
 
#4、獲取內存信息
# 獲取物理內存總量
mem_total=`free -m | grep Mem | awk '{print $2}'`
echo "物理內存總量:"$mem_total
 
# 獲取操作系統已使用內存總量
mem_sys_used=`free -m | grep Mem | awk '{print $3}'`
echo "已使用內存總量(操作系統):"$mem_sys_used
 
# 獲取操作系統未使用內存總量
mem_sys_free=`free -m | grep Mem | awk '{print $4}'`
echo "剩余內存總量(操作系統):"$mem_sys_free
 
# 獲取應用程序已使用的內存總量
mem_user_used=`free -m | sed -n 3p | awk '{print $3}'`
echo "已使用內存總量(應用程序):"$mem_user_used
 
# 獲取應用程序未使用內存總量
mem_user_free=`free -m | sed -n 3p | awk '{print $4}'`
echo "剩余內存總量(應用程序):"$mem_user_free
 
 
# 獲取交換分區總大小
mem_swap_total=`free | grep Swap | awk '{print $2}'`
echo "交換分區總大小:"$mem_swap_total
 
# 獲取已使用交換分區大小
mem_swap_used=`free | grep Swap | awk '{print $3}'`
echo "已使用交換分區大小:"$mem_swap_used
 
# 獲取剩余交換分區大小
mem_swap_free=`free | grep Swap | awk '{print $4}'`
echo "剩余交換分區大小:"$mem_swap_free
 

#5、獲取磁盤I/O統計信息
echo "指定設備(/dev/sda)的統計信息"
# 每秒向設備發起的讀請求次數
disk_sda_rs=`iostat -kx | grep sda| awk '{print $4}'`
echo "每秒向設備發起的讀請求次數:"$disk_sda_rs
 
# 每秒向設備發起的寫請求次數
disk_sda_ws=`iostat -kx | grep sda| awk '{print $5}'`
echo "每秒向設備發起的寫請求次數:"$disk_sda_ws
 
# 向設備發起的I/O請求隊列長度平均值
disk_sda_avgqu_sz=`iostat -kx | grep sda| awk '{print $9}'`
echo "向設備發起的I/O請求隊列長度平均值"$disk_sda_avgqu_sz
 
# 每次向設備發起的I/O請求平均時間
disk_sda_await=`iostat -kx | grep sda| awk '{print $10}'`
echo "每次向設備發起的I/O請求平均時間:"$disk_sda_await
 
# 向設備發起的I/O服務時間均值
disk_sda_svctm=`iostat -kx | grep sda| awk '{print $11}'`
echo "向設備發起的I/O服務時間均值:"$disk_sda_svctm
 
# 向設備發起I/O請求的CPU時間百分占比
disk_sda_util=`iostat -kx | grep sda| awk '{print $12}'`
echo "向設備發起I/O請求的CPU時間百分占比:"$disk_sda_util

2. 執行結果

[root@centos7 ~]# sh yikou.sh 
IP地址:192.168.200.61
cpu總核數:1
用戶空間占用CPU百分比:0.0
內核空間占用CPU百分比:0.0
空閑CPU百分比:93.8
等待輸入輸出占CPU百分比:0.0
CPU中斷次數:59
CPU上下文切換次數:144
CPU 15分鍾前到現在的負載平均值:0.05
CPU 5分鍾前到現在的負載平均值:0.02
CPU 1分鍾前到現在的負載平均值:0.03
CPU任務隊列長度:3
物理內存總量:972
已使用內存總量(操作系統):152
剩余內存總量(操作系統):453
已使用內存總量(應用程序):0
剩余內存總量(應用程序):2047
交換分區總大小:2097148
已使用交換分區大小:0
剩余交換分區大小:2097148
指定設備(/dev/sda)的統計信息
每秒向設備發起的讀請求次數:3.92
每秒向設備發起的寫請求次數:1.09
向設備發起的I/O請求隊列長度平均值0.00
每次向設備發起的I/O請求平均時間:0.33
向設備發起的I/O服務時間均值:0.34
向設備發起I/O請求的CPU時間百分占比:0.31

3. 原理講解

知其然還要知其所以然,下面詳細講解腳本實現的原理

3.1 獲取要監控的本地服務器 IP 地址

IP=`ifconfig | grep inet | grep -vE 'inet6|127.0.0.1' | awk '{print $2}'`
echo "IP地址:"$IP
  • ifconfig | grep inet 過濾出如下結果包含字符串 inet 的行,如下圖紅色圈起來的兩行 其中 | 是管道的意思,將前面命令的結果作為輸入給 | 右邊的命令
  • grep -vE 'inet6|127.0.0.1' 將第一步結果通過命令 grep -vE 過濾掉包含 inet6127.0.0.1 的行
  • 將第二步結果通過命令 awk 將字符串分割,$n(0~N) 對應相應的參數,如下圖多少 $2 對應 地址:192.168.200.61'{print 2}' 打印出
  • 2 的值
  • 將第三步的結果賦值給變量 IP
  • echo "IP 地址:"$IP 打印出變量 IP 的值

image_1f179nms81jod2ekqge1bp51gs09.png-120.3kB

3.2 獲取 cpu 總核數

cpu_num=`grep -c "model name" /proc/cpuinfo`
echo "cpu總核數:"$cpu_num
  • 在 linux 的 /proc 目錄下存放了系統運行的很多系統資源信息,其中 /proc/cpuinfo 存放了系統運行時 cpu 的很多重要信息。
  • 所有的 cpu 核信息由 model name 字符串給出,
  • 通過命令 grep -c "model name" /proc/cpuinfo 可以計算出文件 /proc/cpuinfo 中出現字符串 model name 出現的次數,就可以得到 cpu 總核數。-c 表示統計字符串出現次數。

如下所示:

image_1f179r8uu1boael3el072f9sm.png-153.5kB

3.3 獲取 CPU 利用率

top 命令經常用來監控 linux 的系統狀況,是常用的性能分析工具,能夠實時顯示系統中各個進程的資源占用情況。

# 獲取用戶空間占用CPU百分比
cpu_user=`top -b -n 1 | grep Cpu | awk '{print $2}' | cut -f 1 -d "%"`
echo "用戶空間占用CPU百分比:"$cpu_user
 
# 獲取內核空間占用CPU百分比
cpu_system=`top -b -n 1 | grep Cpu | awk '{print $4}' | cut -f 1 -d "%"`
echo "內核空間占用CPU百分比:"$cpu_system
 
# 獲取空閑CPU百分比
cpu_idle=`top -b -n 1 | grep Cpu | awk '{print $8}' | cut -f 1 -d "%"`
echo "空閑CPU百分比:"$cpu_idle
 
# 獲取等待輸入輸出占CPU百分比
cpu_iowait=`top -b -n 1 | grep Cpu | awk '{print $10}' | cut -f 1 -d "%"`
echo "等待輸入輸出占CPU百分比:"$cpu_iowait

image_1f17aatbs9vq18e2162q11cq1bgm13.png-313.4kB

1.top -b -n 1 顯示系統的信息並以格式化打印,結果只刷新一次

n 設置退出前屏幕刷新的次數
b 將top輸出編排成適合輸出到文件的格式,可以使用這個選項創建進程日志

2.grep Cpu 提取出字符串 Cpu 所在的行

3.awk '{print $2}'將第二步得到的字符串分割,並調用方法 print 打印出 $2 對應的第二個字符串,0.5%us

4.cut -f 1 -d "%" 表示以 % 為分隔符,將第三步的結果分隔開,並顯示分割后的記過的第一個字符串即 0.5

-d  "%" 是以%作為分隔符, 
-f 1顯示以:分割每一行的第一段內容

其他腳本以此類推

其他 Cpu 利用率參數含義如下:

#us 用戶空間占用CPU百分比
#sy 內核空間占用CPU百分比
#ni 用戶進程空間內改變過優先級的進程占用CPU百分比
#id 空閑CPU百分比
#wa 等待輸入輸出的CPU時間百分比
#hi 硬件中斷
#si 軟件中斷

3.4 獲取 CPU 上下文切換和中斷次數

# 獲取CPU中斷次數
cpu_interrupt=`vmstat -n 1 1 | sed -n 3p | awk '{print $11}'`
echo "CPU中斷次數:"$cpu_interrupt
 
# 獲取CPU上下文切換次數
cpu_context_switch=`vmstat -n 1 1 | sed -n 3p | awk '{print $12}'`
echo "CPU上下文切換次數:"$cpu_context_switch

# 獲取任務隊列(就緒狀態等待的進程數)
cpu_task_length=`vmstat -n 1 1 | sed -n 3p | awk '{print $1}'`
echo "CPU任務隊列長度:"$cpu_task_length

1.vmstat 是 Virtual Meomory Statistics(虛擬內存統計)的縮寫,可對操作系統的虛擬內存、進程、CPU 活動進行監控。是對系統的整體情況進行統計,不足之處是無法對某個進程進行深入分析。vmstat -n 1 1 只顯示一次各字段名稱。

-n:只在開始時顯示一次各字段名稱。

2.sed -n 3p 將第一步的結果打印出第 3 行

參數說明:

  • -n或--quiet或--silent 取消自動打印模式空間,僅顯示script處理后的結果。
    動作說明:
  • p :打印,亦即將某個選擇的數據印出。通常 p 會與參數 sed -n 一起運行~

3.awk '{print $1}'` 將第 2 步結果得出的字符串分割,並打印第一個字符串

image_1f17aot6t1g8pi12vtsnl012v31g.png-34.3kB

3.5 獲取 CPU 負載信息

# 獲取CPU15分鍾前到現在的負載平均值
cpu_load_15min=`uptime | awk '{print $11}' | cut -f 1 -d ','`
echo "CPU 15分鍾前到現在的負載平均值:"$cpu_load_15min
 
# 獲取CPU5分鍾前到現在的負載平均值
cpu_load_5min=`uptime | awk '{print $10}' | cut -f 1 -d ','`
echo "CPU 5分鍾前到現在的負載平均值:"$cpu_load_5min
 
# 獲取CPU1分鍾前到現在的負載平均值
cpu_load_1min=`uptime | awk '{print $9}' | cut -f 1 -d ','`
echo "CPU 1分鍾前到現在的負載平均值:"$cpu_load_1min

1.uptime 命令可以用來查看服務器已經運行了多久,當前登錄的用戶有多少,以及服務器在過去的 1 分鍾、5 分鍾、15 分鍾的系統平均負載值。系統負載是處於可運行 runnable 或不可中斷 uninterruptable 狀態的進程的平均數。可運行狀態的進程要么正在使用 CPU 要么在等待使用 CPU。不可中斷狀態的進程則正在等待某些 I/O 訪問,例如等待磁盤 IO。有三個時間間隔的平均值。負載均值的意義根據系統中 CPU 的數量不同而不同,負載為 1 對於一個只有單 CPU 的系統來說意味着負載滿了,而對於一個擁有 4 CPU 的系統來說則意味着 75% 的時間里都是空閑的。

2.參考之前腳本分析,awk '{print $9}' | cut -f 1 -d ',' 將第一步的結果分割開,並得到第 9 個字符串,然后用‘,’分隔開,並得到分割后的第一個字符串

image_1f17aul3nac31d2c14k0qo8ldu1t.png-22.9kB

3.6 獲取內存信息

# 獲取物理內存總量
mem_total=`free -m | grep Mem | awk '{print $2}'`
echo "物理內存總量:"$mem_total
 
# 獲取操作系統已使用內存總量
mem_sys_used=`free -m | grep Mem | awk '{print $3}'`
echo "已使用內存總量(操作系統):"$mem_sys_used
 
# 獲取操作系統未使用內存總量
mem_sys_free=`free -m | grep Mem | awk '{print $4}'`
echo "剩余內存總量(操作系統):"$mem_sys_free
 
# 獲取應用程序已使用的內存總量
mem_user_used=`free -m | sed -n 3p | awk '{print $3}'`
echo "已使用內存總量(應用程序):"$mem_user_used
 
# 獲取應用程序未使用內存總量
mem_user_free=`free -m | sed -n 3p | awk '{print $4}'`
echo "剩余內存總量(應用程序):"$mem_user_free
 
 
# 獲取交換分區總大小
mem_swap_total=`free -m | grep Swap | awk '{print $2}'`
echo "交換分區總大小:"$mem_swap_total
 
# 獲取已使用交換分區大小
mem_swap_used=`free -m | grep Swap | awk '{print $3}'`
echo "已使用交換分區大小:"$mem_swap_used
 
# 獲取剩余交換分區大小
mem_swap_free=`free -m | grep Swap | awk '{print $4}'`
echo "剩余交換分區大小:"$mem_swap_free

1.free 命令顯示系統內存的使用情況,包括物理內存、交換內存 (swap) 和內核緩沖區內存。

2.grep Swap 將第一步的結果過濾只顯示包含字符串 Swap 的行

3.awk '{print $4}' 將第二步結果分割,並打印出第四個字符串的值

image_1f17b296pelo1qr4138ungj2rb2q.png-21.8kB

【其他腳本參考前面的分析】

3.7 獲取磁盤 I/O 統計信息

echo "指定設備(/dev/sda)的統計信息"
# 每秒向設備發起的讀請求次數
disk_sda_rs=`iostat -kx | grep sda| awk '{print $4}'`
echo "每秒向設備發起的讀請求次數:"$disk_sda_rs
 
# 每秒向設備發起的寫請求次數
disk_sda_ws=`iostat -kx | grep sda| awk '{print $5}'`
echo "每秒向設備發起的寫請求次數:"$disk_sda_ws
 
# 向設備發起的I/O請求隊列長度平均值
disk_sda_avgqu_sz=`iostat -kx | grep sda| awk '{print $9}'`
echo "向設備發起的I/O請求隊列長度平均值"$disk_sda_avgqu_sz
 
# 每次向設備發起的I/O請求平均時間
disk_sda_await=`iostat -kx | grep sda| awk '{print $10}'`
echo "每次向設備發起的I/O請求平均時間:"$disk_sda_await
 
# 向設備發起的I/O服務時間均值
disk_sda_svctm=`iostat -kx | grep sda| awk '{print $11}'`
echo "向設備發起的I/O服務時間均值:"$disk_sda_svctm
 
# 向設備發起I/O請求的CPU時間百分占比
disk_sda_util=`iostat -kx | grep sda| awk '{print $12}'`
echo "向設備發起I/O請求的CPU時間百分占比:"$disk_sda_util

1.iostat 命令被用於監視系統輸入輸出設備和 CPU 的使用情況。它的特點是匯報磁盤活動統計情況,同時也會匯報出 CPU 使用情況。

-k:顯示狀態以千字節每秒為單位,而不使用塊每秒
-x:顯示擴展狀態

2.grep sda 用於過濾第一步得到的結果,只顯示包含字符串 sda 的哪一行

3.awk '{print $4}' 將第二步的結果分割,並只顯示第 4 個字符串

image_1f17b7rmc1su2f4g1a7ghu91v6n37.png-73.3kB

參考:https://www.toutiao.com/i6754887380399849998/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM