linux脚本-使用top命令监控进程cpu与mem占用

个人随笔 (Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu)

下面是两个shell脚本程序,算是常用到的两个脚本形式,记录下来,供参考使用。

一个是监控进程cpu与mem占用的;

一个是启动多进程,为程序传递不同数字参数的;

1. linux下使用脚本跟踪一个服务的cpu占用

shell 复制代码
#!/bin/sh
procname=systemd
delay=30
while true
do
# get pid from system
pid=`ps -ef|grep ${procname}|grep -v grep|head -n 1|awk -F' ' '{print $2}'`

# get process info from top command
#echo "top -n 1 -b -p ${pid} "
top -n 1 -b -p ${pid}|awk -F'\n' '$1+0>0 {print strftime("%Y-%m-%d_%H:%M:%S"),$0; fflush();}'|tee -a top.log

# delay a few seconds
sleep ${delay}
done

2. 传递循环数字参数给程序

启动多个进程,监控不同的id范围

shell 复制代码
#!/bin/sh
func=./trace 
for i in $(seq 1 20) 
do  
# calc startid and endid
startid=`expr $i \* 5000`
endid=`expr $startid + 5000`

# start process
echo "$func $startid $endid > ${i}.log"
$func $startid $endid >${i}.log &

done

个人随笔 (Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu)

相关推荐
C++忠实粉丝5 分钟前
计算机网络socket编程(3)_UDP网络编程实现简单聊天室
linux·网络·c++·网络协议·计算机网络·udp
量子网络23 分钟前
debian 如何进入root
linux·服务器·debian
我们的五年30 分钟前
【Linux课程学习】:进程描述---PCB(Process Control Block)
linux·运维·c++
我言秋日胜春朝★1 小时前
【Linux】进程地址空间
linux·运维·服务器
C-cat.2 小时前
Linux|环境变量
linux·运维·服务器
yunfanleo2 小时前
docker run m3e 配置网络,自动重启,GPU等 配置渠道要点
linux·运维·docker
糖豆豆今天也要努力鸭2 小时前
torch.__version__的torch版本和conda list的torch版本不一致
linux·pytorch·python·深度学习·conda·torch
烦躁的大鼻嘎3 小时前
【Linux】深入理解GCC/G++编译流程及库文件管理
linux·运维·服务器
ac.char3 小时前
在 Ubuntu 上安装 Yarn 环境
linux·运维·服务器·ubuntu
敲上瘾3 小时前
操作系统的理解
linux·运维·服务器·c++·大模型·操作系统·aigc