在 Linux 中监控系统 CPU/系统调用

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 的手册页,因为有几个选项。

  • 该死的,徒劳的互斥锁!*握拳* (2认同)

jan*_*neb 2

也许可以尝试其中一种采样分析器,例如 oprofile,或者对于较新的内核,perf。如果你幸运的话,“perf top”可能会准确地告诉你你想要什么。请参阅此处的一些示例