前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Perf分析CPU性能问题笔记

Perf分析CPU性能问题笔记

作者头像
颇忒脱
发布2019-04-21 15:48:58
6.1K0
发布2019-04-21 15:48:58
举报
文章被收录于专栏:颇忒脱的技术博客

本文仅仅是一个笔记。

场景

观察进程的CPU使用情况

观察进程内各个函数的CPU使用情况:

代码语言:javascript
复制
sudo perf top -p <pid>

同时显示函数调用链:

代码语言:javascript
复制
sudo perf top -g -p <pid>

记录采样结果,以供后续分析,加上-g会记录调用链:

代码语言:javascript
复制
sudo perf record -g -p <pid>

读取采样结果:

代码语言:javascript
复制
sudo perf report

观察容器内进程CPU使用情况

容器内的进程实际上可以在host machine上看到,ps -ef | grep <text>可以找得到。

因此同样可以用perf top -p <pid>观察,但是会出现无法显示函数符号的问题,注意观察perf top最下面一行:

代码语言:javascript
复制
Failed to open /opt/bitnami/php/lib/php/extensions/opcache.so, continuing without symbols

解决办法是先用perf record记录采样数据,然后将容器内文件系统绑定到host上,然后用perf report --symfs <path>指定符号目录。你得先安装bindfs(下面有安装方法)。

代码语言:javascript
复制
mkdir /tmp/foo
PID=$(docker inspect --format {{.State.Pid}} <container-name>)
bindfs /proc/$PID/root /tmp/foo
perf report --symfs /tmp/foo

# 使用完成后不要忘记解除绑定
umount /tmp/foo/

把上面的<container-name>改成你要观察的容器名。

观察Java进程的CPU使用情况

你得要先安装perf-map-agent(下面有安装方法),在启动Java进程的时候添加-XX:+PreserveFramePointer参数,下面是几个用法:

  • perf-java-top <pid> <perf-top-options>
  • perf-java-record-stack <pid> <perf-record-options>
  • perf-java-report-stack <pid> <perf-report-options>

更多用法见官网说明。

还可以使用perf-java-flames <pid> <perf-record-options>生成火焰图,你得先安装FlameGraph(下面有安装方法)。关于火焰图的解读看netflix的这篇博客

观察容器内Java进程CPU使用情况

目前没有办法。

附录:安装方法

下面讲的都是在Ubuntu 16.04系统上的安装方法。

perf

安装perf

代码语言:javascript
复制
$ sudo apt install -y linux-tools-common

运行perf会出现:

代码语言:javascript
复制
$ perf
WARNING: perf not found for kernel 4.4.0-145

  You may need to install the following packages for this specific kernel:
    linux-tools-4.4.0-145-generic
    linux-cloud-tools-4.4.0-145-generic

  You may also want to install one of the following packages to keep up to date:
    linux-tools-generic
    linux-cloud-tools-generic

于是安装:

代码语言:javascript
复制
sudo apt install linux-tools-4.4.0-145-generic linux-cloud-tools-4.4.0-145-generic linux-cloud-tools-generic

bindfs

bindfs官网下载源码包(本文写是版本为1.13.11)。

先安装编译需要的工具:

代码语言:javascript
复制
sudo apt install -y cmake pkg-config libfuse-dev libfuse2 autoconf 

解压缩源码包,进入bindfs目录,编译:

代码语言:javascript
复制
./configure && make && sudo make install

perf-map-agent

github clone perf-map-agent的源码仓库。

安装JDK,你之后要监测的程序都得用这个JDK启动,这个JDK也用来编译perf-map-agent。用apt安装openjdk的方法见下面。

编译:

代码语言:javascript
复制
cmake .
make

# will create links to run scripts in /usr/local/bin
sudo bin/create-links-in /usr/local/bin

安装openjdk

代码语言:javascript
复制
sudo apt-get install -y openjdk-8-jdk

通过这种方式安装是没有JAVA_HOME环境变量的,因此我们要自己设置一个,查找openjdk的安装路径:

代码语言:javascript
复制
dpkg-query -L openjdk-8-jdk

将发现结果写到~/.bashrc里:

代码语言:javascript
复制
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
FlameGraph

github clone FlameGraph的源码仓库。

~/.bashrc设置环境变量:

代码语言:javascript
复制
export FLAMEGRAPH_DIR=<path-to-flame-graph>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 场景
    • 观察进程的CPU使用情况
      • 观察容器内进程CPU使用情况
        • 观察Java进程的CPU使用情况
          • 观察容器内Java进程CPU使用情况
          • 附录:安装方法
            • perf
              • bindfs
                • perf-map-agent
                  • 安装openjdk
                    • FlameGraph
                相关产品与服务
                容器服务
                腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档