本文仅仅是一个笔记。
场景
观察进程的CPU使用情况
观察进程内各个函数的CPU使用情况:
sudo perf top -p
同时显示函数调用链:
sudo perf top -g -p
记录采样结果,以供后续分析,加上-g会记录调用链:
sudo perf record -g -p
读取采样结果:
sudo perf report
观察容器内进程CPU使用情况
容器内的进程实际上可以在host machine上看到,ps -ef | grep 可以找得到。
因此同样可以用perf top -p 观察,但是会出现无法显示函数符号的问题,注意观察perf top最下面一行:
Failed to open /opt/bitnami/php/lib/php/extensions/opcache.so, continuing without symbols
解决办法是先用perf record记录采样数据,然后将容器内文件系统绑定到host上,然后用perf report --symfs 指定符号目录。你得先安装bindfs(下面有安装方法)。
mkdir /tmp/foo
PID=$(docker inspect --format { {.State.Pid}} )
bindfs /proc/$PID/root /tmp/foo
perf report --symfs /tmp/foo
# 使用完成后不要忘记解除绑定
umount /tmp/foo/
把上面的改成你要观察的容器名。
观察Java进程的CP