在Linux中监视系统CPU /系统调用
发布时间:2020-12-13 18:27:23 所属栏目:Linux 来源:网络整理
导读:我有几个进程占用了大量的系统CPU时间(通过查看vmstat确定).有没有一种简单的方法可以找出正在进行的系统调用? 我知道有strace,但是有更快更简单的方法吗?系统调用是否存在类似“顶层”的东西? 解决方法 我认为使用-c标志的strace可能是我所知道的最接近
我有几个进程占用了大量的系统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的手册页,因为有几个选项. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |