实时监控服务器CPU、内存和磁盘使用率

实时监控服务器CPU、内存和磁盘使用率
监控内存使用率:

free -g | awk 'NR==2{printf "%.2f%%\t\t", $3*100/$2 }'

awk 'NR==2{...}' 取第二行(Mem 行)。
$3 为已用内存,$2 为总内存,$3*100/$2 即计算使用率。

监控磁盘使用率:

df -h | awk '$NF=="/"{printf "%s\t\t", $5}'

$NF=="/" 表示匹配挂载在根目录 / 的那一行。
$5 是使用率字段,形如 7%。

监控 CPU 使用率:

top -bn1 | grep load | awk '{printf "%.2f%%\t\t\n", $(NF-2)}'

top -bn1:一次性以 batch 模式运行 top 命令。
grep load:筛选包含 load average 的行。
$(NF-2):倒数第三个字段,即 1 分钟平均负载(例如 0.00),我们将其近似表示为 CPU 使用率。

合并:

#!/bin/bash
printf "内存使用率\t\t磁盘使用率\t\tCPU\n"
end=$((SECONDS+60))  # 运行一分钟,可修改为任意秒数

while [ $SECONDS -lt $end ]; do
  MEM=$(free -m | awk 'NR==2{printf "%.2f%%\t\t", $3*100/$2 }')
  DISK=$(df -h | awk '$NF=="/"{printf "%s\t\t", $5}')
  CPU=$(top -bn1 | grep load | awk '{printf "%.2f%%\t\t\n", $(NF-2)}')
  echo "$MEM$DISK$CPU"
  sleep 10
done

你可能感兴趣的:(服务器,运维)