linux监控某个进程内存占用

1.基本思路:

  

写道
1.获得这个进程内存信息
2.将内存信息定时输出到日志文件

 2.实现:

写道
1.实时内存信息
/proc/进程ID/status
2.将这个信息写入到 脚本中

 

2.1

先看一个初始化的简单脚本:

 

写道
#! /bin/bash
pid=$(cat /home/dc_workspace/logs/DataCell.pid)
echo $pid
while (true)
do
currentTime=`date +%y-%m-%d-%X-%Z`
echo $currentTime
echo $currentTime"-------------------------" >> /home/dc_workspace/logs/$pid.mem
cat /proc/$pid/status | grep Vm >> /home/dc_workspace/logs/$pid.mem
sleep 10s
done

 

3.脚本代码:

这个脚本有两个输入参数:  pid文件的路径 和 内存输出的,最后输出的文件信息在 和pid文件在相同的目录下  $pid.mem 文件中,

 

 

#! /bin/bash
pidFile=$1
sleepTime=$2
if [ ! $pidFile ] ;then
 echo "please set pid file path"
 exit 0
fi

if [ -f $pidFile ] ; then
  echo $pidFile
else
  echo $pidFile" pid file path not exist"
  exit 0
fi

if [ ! $sleepTime ] ; then
  sleepTime=10
fi
pid=`cat $pidFile`
pidPath=${pidFile%/*}

echo $pid
echo "pidPath: "$pidPath
while [ $pid ]
do
  currentTime=`date +%y-%m-%d-%X-%Z`
  echo $currentTime
  echo $currentTime"-------------------------"  >> $pidPath/$pid.mem
  cat /proc/$pid/status | grep Vm  >>  $pidPath/$pid.mem
  sleep $sleepTime
done

 

 

4.看下输出结果吧:

写道
13-08-30-15时13分18秒-CST-------------------------
VmPeak: 11303480 kB
VmSize: 10697548 kB
VmLck: 0 kB
VmHWM: 4122892 kB
VmRSS: 1931880 kB
VmData: 10225608 kB
VmStk: 88 kB
VmExe: 4940 kB
VmLib: 10180 kB
VmPTE: 6500 kB
VmSwap: 0 kB
13-08-30-15时13分28秒-CST-------------------------
VmPeak: 11303480 kB
VmSize: 10687228 kB
VmLck: 0 kB
VmHWM: 4122892 kB
VmRSS: 1993228 kB
VmData: 10225608 kB
VmStk: 88 kB
VmExe: 4940 kB
VmLib: 10180 kB
VmPTE: 6476 kB
VmSwap: 0 kB

 

你可能感兴趣的:(linux)