1.基本思路:
写道
1.获得这个进程内存信息
2.将内存信息定时输出到日志文件
2.将内存信息定时输出到日志文件
2.实现:
写道
1.实时内存信息
/proc/进程ID/status
2.将这个信息写入到 脚本中
/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
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
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