摘要:本文僅僅是一個筆記。因此同樣可以用觀察,但是會出現無法顯示函數符號的問題,注意觀察最下面一行解決辦法是先用記錄采樣數據,然后將容器內文件系統綁定到上,然后用指定符號目錄。觀察容器內進程使用情況目前沒有辦法。
本文僅僅是一個筆記。
場景 觀察進程的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
Failed to open /opt/bitnami/php/lib/php/extensions/opcache.so, continuing without symbols
解決辦法是先用perf record記錄采樣數據,然后將容器內文件系統綁定到host上,然后用perf report --symfs
mkdir /tmp/foo PID=$(docker inspect --format {{.State.Pid}}) bindfs /proc/$PID/root /tmp/foo perf report --symfs /tmp/foo # 使用完成后不要忘記解除綁定 umount /tmp/foo/
把上面的
你得要先安裝perf-map-agent(下面有安裝方法),在啟動Java進程的時候添加-XX:+PreserveFramePointer參數,下面是幾個用法:
perf-java-top
perf-java-record-stack
perf-java-report-stack
更多用法見官網說明。
還可以使用perf-java-flames
目前沒有辦法。
附錄:安裝方法下面講的都是在Ubuntu 16.04系統上的安裝方法。
perf安裝perf
$ sudo apt install -y linux-tools-common
運行perf會出現:
$ 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-genericbindfs
到bindfs官網下載源碼包(本文寫是版本為1.13.11)。
先安裝編譯需要的工具:
sudo apt install -y cmake pkg-config libfuse-dev libfuse2 autoconf
解壓縮源碼包,進入bindfs目錄,編譯:
./configure && make && sudo make installperf-map-agent
到github clone perf-map-agent的源碼倉庫。
安裝JDK,你之后要監測的程序都得用這個JDK啟動,這個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環境變量的,因此我們要自己設置一個,查找openjdk的安裝路徑:
dpkg-query -L openjdk-8-jdk
將發現結果寫到~/.bashrc里:
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64FlameGraph
到github clone FlameGraph的源碼倉庫。
到~/.bashrc設置環境變量:
export FLAMEGRAPH_DIR=
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/77577.html
摘要:本文是關于我如何應用基本性能分析技術,借助火焰圖做了一處小改進,使得我們計算機集群的狀況獲得了倍的改善,并在第二年幫助節省了幾百萬刀。最終,通過對平均大小在的事件進行批量插入,我們的吞吐量獲得了的提高。 本文是關于我如何應用基本性能分析技術,借助火焰圖做了一處小改進,使得我們 Postgres 計算機集群的 CPU 狀況獲得了 10 倍的改善,并在第二年幫助 Heap 節省了幾百萬刀。針對用...
摘要:什么是火焰圖怎么用以下會為你一一解答。工具包標準分析器,用于生成系統堆棧信息提供轉換成帶標示的代理生成火焰圖的工具生成全部進程的堆棧信息還有一些問題很多方法都是缺少的,對比起,在圖里的堆棧信息可能只有的深度。 什么是FlameGraph火焰圖?怎么用?以下會為你一一解答。 Lets Go! 1.結論 如果能生成出來對應圖表,分析java使用cpu性能很好用。 但是有時生成出來的堆棧...
閱讀 2329·2021-09-30 09:47
閱讀 2949·2019-08-30 11:05
閱讀 2526·2019-08-29 17:20
閱讀 1912·2019-08-29 13:01
閱讀 1721·2019-08-26 13:39
閱讀 1221·2019-08-26 13:26
閱讀 3204·2019-08-23 18:40
閱讀 1809·2019-08-23 17:09