场景
观察进程的CPU使用情况
观察进程内各个函数的CPU使用情况:
|
|
同时显示函数调用链:
|
|
记录采样结果,以供后续分析,加上-g
会记录调用链:
|
|
读取采样结果:
|
|
观察容器内进程CPU使用情况
容器内的进程实际上可以在host machine上看到,ps -ef | grep <text>
可以找得到。
因此同样可以用perf top -p <pid>
观察,但是会出现无法显示函数符号的问题,注意观察perf top
最下面一行:
|
|
解决办法是先用perf record
记录采样数据,然后将容器内文件系统绑定到host上,然后用perf report --symfs <path>
指定符号目录。你得先安装bindfs(下面有安装方法)。
|
|
把上面的<container-name>
改成你要观察的容器名。
观察Java进程的CPU使用情况
你得要先安装perf-map-agent(下面有安装方法),在启动Java进程的时候添加-XX:+PreserveFramePointer
参数,下面是几个用法:
perf-java-top <pid> <perf-top-options>
PERF_RECORD_SECONDS=30 perf-java-record-stack <pid> <perf-record-options>
PERF_RECORD_SECONDS=30 perf-java-report-stack <pid> <perf-report-options>
更多用法见官网说明。
还可以使用PERF_RECORD_SECONDS=30 perf-java-flames <pid> <perf-record-options>
生成火焰图,你得先安装FlameGraph(下面有安装方法)。关于火焰图的解读看netflix的这篇博客。
观察容器内Java进程CPU使用情况
目前没有办法。
附录:安装方法
下面讲的都是在Ubuntu 16.04系统上的安装方法。
perf
安装perf
|
|
运行perf会出现:
|
|
于是安装:
|
|
bindfs
到bindfs官网下载源码包(本文写是版本为1.13.11)。
先安装编译需要的工具:
|
|
解压缩源码包,进入bindfs目录,编译:
|
|
perf-map-agent
到github clone perf-map-agent的源码仓库。
安装JDK,你之后要监测的程序都得用这个JDK启动,这个JDK也用来编译perf-map-agent。用apt安装openjdk的方法见下面。
编译:
|
|
安装openjdk
|
|
通过这种方式安装是没有JAVA_HOME环境变量的,因此我们要自己设置一个,查找openjdk的安装路径:
|
|
将发现结果写到~/.bashrc
里:
|
|
FlameGraph
到github clone FlameGraph的源码仓库。
到~/.bashrc
设置环境变量:
|
|
BCC
官方安装文档。
如果你是Ubuntu 18.04:
|
|
如果你是Ubuntu 16.40:
|
|
安装路径在:/usr/share/bcc/tools
。
评论