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

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值