shell脚本检查内存使用情况
时间:2020-03-05 15:31:45 来源:igfitidea点击:
在本教程中,我将显示一个shell脚本,用于检查每个程序或者Linux上的应用程序的内存使用情况。
脚本输出在Linux中运行的每个程序的共享和私有内存。
由于内存计算有点复杂,因此此shell脚本尝试最佳地查找更准确的结果。
此脚本使用2个文件即"/proc/../status"(获取进程的名称)和"/proc/../smaps",以获取进程的内存统计信息。
然后脚本将所有数据转换为KB,MB,GB。
此外,请确保安装BC命令。
shell脚本检查内存使用情况
检查以下脚本,该脚本计算内存使用和打印输出。
#!/bin/bash
# Make sure only root can run our script
if [ "$(id -u)" != "0" ]; then
echo "This script must be run as root" 1>&2
exit 1
fi
### Functions
#This function will count memory statistic for passed PID
get_process_mem ()
{
PID=
#we need to check if 2 files exist
if [ -f /proc/$PID/status ];
then
if [ -f /proc/$PID/smaps ];
then
#here we count memory usage, Pss, Private and Shared = Pss-Private
Pss=`cat /proc/$PID/smaps | grep -e "^Pss:" | awk '{print }'| paste -sd+ | bc `
Private=`cat /proc/$PID/smaps | grep -e "^Private" | awk '{print }'| paste -sd+ | bc `
#we need to be sure that we count Pss and Private memory, to avoid errors
if [ x"$Rss" != "x" -o x"$Private" != "x" ];
then
let Shared=${Pss}-${Private}
Name=`cat /proc/$PID/status | grep -e "^Name:" |cut -d':' -f2`
#we keep all results in bytes
let Shared=${Shared}*1024
let Private=${Private}*1024
let Sum=${Shared}+${Private}
echo -e "$Private + $Shared = $Sum \t $Name"
fi
fi
fi
}
#this function make conversion from bytes to Kb or Mb or Gb
convert()
{
value=
power=0
#if value 0, we make it like 0.00
if [ "$value" = "0" ];
then
value="0.00"
fi
#We make conversion till value bigger than 1024, and if yes we divide by 1024
while [ $(echo "${value} > 1024"|bc) -eq 1 ]
do
value=$(echo "scale=2;${value}/1024" |bc)
let power=$power+1
done
#this part get b,kb,mb or gb according to number of divisions
case $power in
0) reg=b;;
1) reg=kb;;
2) reg=mb;;
3) reg=gb;;
esac
echo -n "${value} ${reg} "
}
#to ensure that temp files not exist
[[ -f /tmp/res ]] && rm -f /tmp/res
[[ -f /tmp/res2 ]] && rm -f /tmp/res2
[[ -f /tmp/res3 ]] && rm -f /tmp/res3
#if argument passed script will show statistic only for that pid, of not – we list all processes in /proc/#and get statistic for all of them, all result we store in file /tmp/res
if [ $# -eq 0 ]
then
pids=`ls /proc | grep -e [0-9] | grep -v [A-Za-z] `
for i in $pids
do
get_process_mem $i >> /tmp/res
done
else
get_process_mem >> /tmp/res
fi
#This will sort result by memory usage
cat /tmp/res | sort -gr -k 5 > /tmp/res2
#this part will get uniq names from process list, and we will add all lines with same process list
#we will count nomber of processes with same name, so if more that 1 process where will be
# process(2) in output
for Name in `cat /tmp/res2 | awk '{print }' | sort | uniq`
do
count=`cat /tmp/res2 | awk -v src=$Name '{if (==src) {print }}'|wc -l| awk '{print }'`
if [ $count = "1" ];
then
count=""
else
count="(${count})"
fi
VmSizeKB=`cat /tmp/res2 | awk -v src=$Name '{if (==src) {print }}' | paste -sd+ | bc`
VmRssKB=`cat /tmp/res2 | awk -v src=$Name '{if (==src) {print }}' | paste -sd+ | bc`
total=`cat /tmp/res2 | awk '{print }' | paste -sd+ | bc`
Sum=`echo "${VmRssKB}+${VmSizeKB}"|bc`
#all result stored in /tmp/res3 file
echo -e "$VmSizeKB + $VmRssKB = $Sum \t ${Name}${count}" >>/tmp/res3
done
#this make sort once more.
cat /tmp/res3 | sort -gr -k 5 | uniq > /tmp/res
#now we print result , first header
echo -e "Private \t + \t Shared \t = \t 内存 used \t Program"
#after we read line by line of temp file
while read line
do
echo $line | while read a b c d e f
do
#we print all processes if Ram used if not 0
if [ $e != "0" ]; then
#here we use function that make conversion
echo -en "`convert $a` \t $b \t `convert $c` \t $d \t `convert $e` \t $f"
echo ""
fi
done
done < /tmp/res
#this part print footer, with counted Ram usage
echo "--------------------------------------------------------"
echo -e "\t\t\t\t\t\t `convert $total`"
echo "========================================================"
# we clean temporary file
[[ -f /tmp/res ]] && rm -f /tmp/res
[[ -f /tmp/res2 ]] && rm -f /tmp/res2
[[ -f /tmp/res3 ]] && rm -f /tmp/res3
shell脚本输出
我已将此脚本命名为"Memstat.sh",并通过运行脚本如下查找输出:
[root@centos-cluster-node1 ~]# ./memstat.sh Private + Shared = 内存 used Program 36.26 mb + 268.00 kb = 36.52 mb python 20.49 mb + 238.00 kb = 20.72 mb iscsiuio 4.78 mb + 451.00 kb = 5.22 mb rgmanager(2) 3.62 mb + 283.00 kb = 3.90 mb NetworkManager 2.53 mb + 1.36 mb = 3.89 mb sshd(3) 2.30 mb + 355.00 kb = 2.64 mb multipathd 984.00 kb + 314.00 kb = 1.26 mb pickup 976.00 kb + 316.00 kb = 1.26 mb master 1.07 mb + 21.00 kb = 1.09 mb rsyslogd 804.00 kb + 240.00 kb = 1.01 mb modem-manager 904.00 kb + 40.00 kb = 944.00 kb pcscd 804.00 kb + 33.00 kb = 837.00 kb ricci 788.00 kb + 38.00 kb = 826.00 kb dbus-daemon 660.00 kb + 32.00 kb = 692.00 kb crond 536.00 kb + 69.00 kb = 605.00 kb rpc.statd 528.00 kb + 46.00 kb = 574.00 kb init 216.00 kb + 357.00 kb = 573.00 kb saslauthd(5) 544.00 kb + 21.00 kb = 565.00 kb wpa_supplicant 484.00 kb + 72.00 kb = 556.00 kb mingetty(6) 316.00 kb + 58.00 kb = 374.00 kb rpcbind 116.00 kb + 237.00 kb = 353.00 kb memstat.sh 328.00 kb + 13.00 kb = 341.00 kb auditd 248.00 kb + 84.00 kb = 332.00 kb hald-runner 312.00 kb + 8.00 kb = 320.00 kb oddjobd 216.00 kb + 81.00 kb = 297.00 kb hald-addon-stor 196.00 kb + 88.00 kb = 284.00 kb hald-addon-inpu 272.00 kb + 4.00 kb = 276.00 kb rpc.idmapd 176.00 kb + 52.00 kb = 228.00 kb hald-addon-acpi ------------------------------------------------------- 98.57 mb ======================================================== [root@centos-cluster-node1 ~]#

