成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Perf分析CPU性能問題筆記

paulquei / 1990人閱讀

摘要:本文僅僅是一個(gè)筆記。因此同樣可以用觀察,但是會(huì)出現(xiàn)無法顯示函數(shù)符號(hào)的問題,注意觀察最下面一行解決辦法是先用記錄采樣數(shù)據(jù),然后將容器內(nèi)文件系統(tǒng)綁定到上,然后用指定符號(hào)目錄。觀察容器內(nèi)進(jìn)程使用情況目前沒有辦法。

本文僅僅是一個(gè)筆記。

場(chǎng)景 觀察進(jìn)程的CPU使用情況

觀察進(jìn)程內(nèi)各個(gè)函數(shù)的CPU使用情況:

sudo perf top -p 

同時(shí)顯示函數(shù)調(diào)用鏈:

sudo perf top -g -p 

記錄采樣結(jié)果,以供后續(xù)分析,加上-g會(huì)記錄調(diào)用鏈:

sudo perf record -g -p 

讀取采樣結(jié)果:

sudo perf report
觀察容器內(nèi)進(jìn)程CPU使用情況

容器內(nèi)的進(jìn)程實(shí)際上可以在host machine上看到,ps -ef | grep 可以找得到。

因此同樣可以用perf top -p 觀察,但是會(huì)出現(xiàn)無法顯示函數(shù)符號(hào)的問題,注意觀察perf top最下面一行:

Failed to open /opt/bitnami/php/lib/php/extensions/opcache.so, continuing without symbols

解決辦法是先用perf record記錄采樣數(shù)據(jù),然后將容器內(nèi)文件系統(tǒng)綁定到host上,然后用perf report --symfs 指定符號(hào)目錄。你得先安裝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進(jìn)程的CPU使用情況

你得要先安裝perf-map-agent(下面有安裝方法),在啟動(dòng)Java進(jìn)程的時(shí)候添加-XX:+PreserveFramePointer參數(shù),下面是幾個(gè)用法:

perf-java-top

perf-java-record-stack

perf-java-report-stack

更多用法見官網(wǎng)說明。

還可以使用perf-java-flames 生成火焰圖,你得先安裝FlameGraph(下面有安裝方法)。關(guān)于火焰圖的解讀看netflix的這篇博客。

觀察容器內(nèi)Java進(jìn)程CPU使用情況

目前沒有辦法。

附錄:安裝方法

下面講的都是在Ubuntu 16.04系統(tǒng)上的安裝方法。

perf

安裝perf

$ sudo apt install -y linux-tools-common

運(yùn)行perf會(huì)出現(xiàn):

$ 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

于是安裝:

sudo apt install linux-tools-4.4.0-145-generic linux-cloud-tools-4.4.0-145-generic linux-cloud-tools-generic
bindfs

到bindfs官網(wǎng)下載源碼包(本文寫是版本為1.13.11)。

先安裝編譯需要的工具:

sudo apt install -y cmake pkg-config libfuse-dev libfuse2 autoconf 

解壓縮源碼包,進(jìn)入bindfs目錄,編譯:

./configure && make && sudo make install
perf-map-agent

到github clone perf-map-agent的源碼倉庫。

安裝JDK,你之后要監(jiān)測(cè)的程序都得用這個(gè)JDK啟動(dòng),這個(gè)JDK也用來編譯perf-map-agent。用apt安裝openjdk的方法見下面。

編譯:

cmake .
make

# will create links to run scripts in /usr/local/bin
sudo bin/create-links-in /usr/local/bin
安裝openjdk
sudo apt-get install -y openjdk-8-jdk

通過這種方式安裝是沒有JAVA_HOME環(huán)境變量的,因此我們要自己設(shè)置一個(gè),查找openjdk的安裝路徑:

dpkg-query -L openjdk-8-jdk

將發(fā)現(xiàn)結(jié)果寫到~/.bashrc里:

export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
FlameGraph

到github clone FlameGraph的源碼倉庫。

~/.bashrc設(shè)置環(huán)境變量:

export FLAMEGRAPH_DIR=

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/77577.html

相關(guān)文章

  • 基本性能分析,省了幾百萬美元

    摘要:本文是關(guān)于我如何應(yīng)用基本性能分析技術(shù),借助火焰圖做了一處小改進(jìn),使得我們計(jì)算機(jī)集群的狀況獲得了倍的改善,并在第二年幫助節(jié)省了幾百萬刀。最終,通過對(duì)平均大小在的事件進(jìn)行批量插入,我們的吞吐量獲得了的提高。 本文是關(guān)于我如何應(yīng)用基本性能分析技術(shù),借助火焰圖做了一處小改進(jìn),使得我們 Postgres 計(jì)算機(jī)集群的 CPU 狀況獲得了 10 倍的改善,并在第二年幫助 Heap 節(jié)省了幾百萬刀。針對(duì)用...

    張憲坤 評(píng)論0 收藏0
  • Java-FlameGraph火焰圖

    摘要:什么是火焰圖怎么用以下會(huì)為你一一解答。工具包標(biāo)準(zhǔn)分析器,用于生成系統(tǒng)堆棧信息提供轉(zhuǎn)換成帶標(biāo)示的代理生成火焰圖的工具生成全部進(jìn)程的堆棧信息還有一些問題很多方法都是缺少的,對(duì)比起,在圖里的堆棧信息可能只有的深度。 什么是FlameGraph火焰圖?怎么用?以下會(huì)為你一一解答。 Lets Go! 1.結(jié)論 如果能生成出來對(duì)應(yīng)圖表,分析java使用cpu性能很好用。 但是有時(shí)生成出來的堆棧...

    shleyZ 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<