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)

相关推荐
成为你的宁宁7 分钟前
【Linux Swap 交换分区:定义、作用与操作指南】
linux·交换分区
祁鱼鱼鱼鱼鱼1 小时前
rhce-shell条件测试
linux·运维
wefg11 小时前
【Linux】文件管理
linux·运维·服务器
hweiyu002 小时前
Linux 命令:split
linux·运维·服务器
dingdingfish2 小时前
GNU Parallel 学习 - 第1章:How to read this book
bash·shell·gnu·parallel
lihe7582 小时前
每天凌晨3点自动同步UBUNTU源
linux·运维·ubuntu·本地源
添砖java‘’2 小时前
线程的互斥与同步
linux·c++·操作系统·线程·信息与通信
tod1133 小时前
Makefile进阶(上)
linux·运维·服务器·windows·makefile·进程
阳光九叶草LXGZXJ3 小时前
达梦数据库-学习-50-分区表指定分区清理空洞率(交换分区方式)
linux·运维·数据库·sql·学习
zbliquan3 小时前
SS928v100远程ubuntu交叉编译开发环境搭建
linux·运维·ubuntu