我想知道Linux上单个进程的CPU和内存使用情况——我知道PID。希望我每秒钟都能得到它,并使用'watch'命令将其写入CSV。我可以使用什么命令从Linux命令行中获得这些信息?
当前回答
您可以通过使用的进程名获取结果
ps -C chrome -o %cpu,%mem,cmd
-C选项允许你在不知道pid的情况下使用进程名。
其他回答
caf的答案是: Top -p <pid>
这将自动刷新CPU使用情况,因此非常适合监控。
Ps命令(不应使用):
CPU使用率目前表示为进程整个生命周期中运行所花费时间的百分比。
最高命令(应使用):
自上次屏幕更新以来,任务占用CPU时间的份额,表示为总CPU时间的百分比。
使用top实时获取CPU使用情况(当前短间隔):
Top -b -n 2 -d 0.2 -p 6962 | tail -1 | awk '{打印$9}'
会像这样回响:78.6
- b:批处理模式 -n 2:迭代次数,使用2是因为:当你第一次运行它时,它没有前值 样本进行比较,因此这些初始值是启动后的百分比。 -d 0.2:延时时间(单位:秒,这里是200ms) -p 6962: monitor - pid 尾部-1:最后一行 Awk '{print $9}':第9列(CPU使用率)
我用htop
sudo apt install htop
htop
按F3查找感兴趣的进程,记住PID。用q退出并再次启动htop,只显示您想要的进程
htop -p $PID
您可以通过使用的进程名获取结果
ps -C chrome -o %cpu,%mem,cmd
-C选项允许你在不知道pid的情况下使用进程名。
根据@caf的回答,这对我来说很有效。
计算给定PID的平均值:
measure.sh
times=100
total=0
for i in $(seq 1 $times)
do
OUTPUT=$(top -b -n 1 -d 0.1 -p $1 | tail -1 | awk '{print $9}')
echo -n "$i time: ${OUTPUT}"\\r
total=`echo "$total + $OUTPUT" | bc -l`
done
#echo "Average: $total / $times" | bc
average=`echo "scale=2; $total / $times" | bc`
echo "Average: $average"
用法:
# send PID as argument
sh measure.sh 3282
推荐文章
- 如何将文件指针(file * fp)转换为文件描述符(int fd)?
- 自定义c++分配器的引人注目的例子?
- Linux Bash中双&和分号有什么区别?
- 如何合并2 JSON对象从2个文件使用jq?
- MySQL CPU使用率高
- 在SSH会话中查找客户端的IP地址
- C++ Linux的想法?
- 如何为Fedora安装g++ ?
- Linux删除大小为0的文件
- Spring引导应用程序作为服务
- 如何重定向标准derr和标准输出到不同的文件在同一行脚本?
- Windows和Linux上的c++编译:ifdef开关
- Linux: kill后台任务
- 如何修改Linux系统中打开文件的数量限制?
- 删除Bash脚本中的重复条目