baj*_*ife 9 linux monitoring performance central-processing-unit strace
我有几个进程占用了大量系统 CPU 时间(通过查看 vmstat 确定)。有没有一种简单的方法可以找出正在执行的系统调用类型?
我知道有 strace,但是有没有更快更简单的方法?是否存在类似于系统调用的“顶部”之类的东西?
Chr*_*ell 17
我认为带有-c
标志的strace可能是我所知道的最接近的。如果您尚未使用该-c
标志,请尝试以下操作:
$ sudo strace -c -p 12345
Run Code Online (Sandbox Code Playgroud)
其中 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
Run Code Online (Sandbox Code Playgroud)
如您所见,这是应用程序进行的所有系统调用的细分,按总时间排序,包括每次调用的平均时间和每个系统调用的调用次数。如果您想对它们进行不同的排序,请参阅 strace 的手册页,因为有几个选项。