在Linux中监视系统CPU 系统调用

在Linux中监视系统CPU 系统调用,第1张

概述我有几个进程占用了大量的系统CPU时间(通过查看vmstat确定).有没有一种简单的方法可以找出正在进行的系统调用? 我知道有strace,但是有更快更简单的方法吗?系统调用是否存在类似“顶层”的东西? 我认为使用-c标志的strace可能是我所知道的最接近的.如果您还没有使用-c标志,请尝试以下方法: $ sudo strace -c -p 12345 其中12345是相关过程的过程ID(PID 我有几个进程占用了大量的系统cpu时间(通过查看vmstat确定).有没有一种简单的方法可以找出正在进行的系统调用?

我知道有strace,但是有更快更简单的方法吗?系统调用是否存在类似“顶层”的东西?

解决方法 我认为使用-c标志的strace可能是我所知道的最接近的.如果您还没有使用-c标志,请尝试以下方法:
$ sudo strace -c -p 12345

其中12345是相关过程的过程ID(PID).请注意,对进程执行 *** 作会增加额外的开销,因此在跟踪进程时,进程运行速度会变慢.

在运行它之后,您想要收集数据,请按Ctrl-C停止数据收集并输出结果.它会产生这样的东西:

% time     seconds  usecs/call     calls    errors syscall------ ----------- ----------- --------- --------- ---------------- 31.88    0.001738         145        12           futex 16.79    0.000915          11        80           tgkill 12.36    0.000674          34        20           read  9.76    0.000532         266         2           statfs  8.42    0.000459          13        35           time  4.38    0.000239           6        40           gettimeofday  3.65    0.000199           4        48           sigprocmask  2.94    0.000160          18         9           open  2.88    0.000157          12        13           stat64  1.32    0.000072           9         8           munmap  0.90    0.000049           6         8           mmap2  0.88    0.000048           3        14         7 sigreturn  0.79    0.000043           5         9           close  0.77    0.000042           4        10           rt_sigprocmask  0.64    0.000035           3        12           setitimer  0.55    0.000030           5         6         6 rt_sigsuspend  0.53    0.000029           4         8           fstat64  0.29    0.000016           8         2           setresuID32  0.13    0.000007           4         2           _llseek  0.09    0.000005           3         2           prctl  0.04    0.000002           2         1           geteuID32------ ----------- ----------- --------- --------- ----------------100.00    0.005451                   341        13 total

如您所见,这是应用程序进行的所有系统调用的细分,按总时间排序,包括每次调用的平均时间和每个系统调用的调用次数.如果您想对它们进行不同的排序,请参阅strace的手册页,因为有几个选项.

总结

以上是内存溢出为你收集整理的在Linux中监视系统CPU /系统调用全部内容,希望文章能够帮你解决在Linux中监视系统CPU /系统调用所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/1044793.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-24
下一篇 2022-05-24

发表评论

登录后才能评论

评论列表(0条)

保存