<!DOCTYPE html>
< html lang = "zh-CN" >
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width,initial-scale=1" >
< meta name = "generator" content = "VuePress 2.0.0-beta.49" >
< style >
:root {
--c-bg: #fff;
}
html.dark {
--c-bg: #22272e;
}
html, body {
background-color: var(--c-bg);
}
< / style >
< script >
const userMode = localStorage.getItem('vuepress-color-scheme');
const systemDarkMode = window.matchMedia & & window.matchMedia('(prefers-color-scheme: dark)').matches;
if (userMode === 'dark' || (userMode !== 'light' & & systemDarkMode)) {
document.documentElement.classList.toggle('dark', true);
}
< / script >
< link rel = "icon" href = "/images/favicon.ico" > < meta name = "viewport" content = "width=device-width, initial-scale=1.0" > < meta property = "og:title" content = "Arthas" > < meta property = "og:image:alt" content = "Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas - alibaba/arthas: Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas" > < meta property = "og:image" content = "/images/arthas_mate_image.png" > < meta property = "og:description" content = "Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas - alibaba/arthas: Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas" > < meta property = "og:image:width" content = "1200" > < meta property = "og:image:height" content = "600" > < meta property = "twitter:image:src" content = "/images/arthas_mate_image.png" > < meta property = "twitter:image:alt" content = "Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas - alibaba/arthas: Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas" > < meta itemprop = "name" content = "Arthas" > < meta itemprop = "image" content = "/images/arthas_mate_image.png" > < meta itemprop = "description" content = "Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas - alibaba/arthas: Alibaba Java Diagnostic Tool Arthas/Alibaba Java诊断利器Arthas" > < script >
var _hmt = _hmt || [];
(function() {
var hm = document.createElement("script");
hm.src = "https://hm.baidu.com/hm.js?d5c5e25b100f0eb51a4c35c8a86ea9b4";
var s = document.getElementsByTagName("script")[0];
s.parentNode.insertBefore(hm, s);
})();
< / script > < title > profiler | arthas< / title > < meta name = "description" content = "arthas 使用文档" >
< link rel = "modulepreload" href = "/assets/app.bd2aade7.js" > < link rel = "modulepreload" href = "/assets/profiler.html.8e89a25b.js" > < link rel = "modulepreload" href = "/assets/arthas-output-svg.a3bef681.js" > < link rel = "modulepreload" href = "/assets/profiler.html.cd7e1584.js" > < link rel = "prefetch" href = "/assets/index.html.ec74869a.js" > < link rel = "prefetch" href = "/assets/index.html.d3cced9f.js" > < link rel = "prefetch" href = "/assets/index.html.c11a8683.js" > < link rel = "prefetch" href = "/assets/advanced-use.html.d690d46c.js" > < link rel = "prefetch" href = "/assets/advice-class.html.4e93ebd7.js" > < link rel = "prefetch" href = "/assets/agent.html.a02fd5cb.js" > < link rel = "prefetch" href = "/assets/arthas-properties.html.e0301951.js" > < link rel = "prefetch" href = "/assets/arthas3.html.d1633eb8.js" > < link rel = "prefetch" href = "/assets/async.html.17ea43ab.js" > < link rel = "prefetch" href = "/assets/auth.html.37ca6bb5.js" > < link rel = "prefetch" href = "/assets/base64.html.b9530fc8.js" > < link rel = "prefetch" href = "/assets/batch-support.html.a2be35e2.js" > < link rel = "prefetch" href = "/assets/cat.html.42885227.js" > < link rel = "prefetch" href = "/assets/classloader.html.faacf70e.js" > < link rel = "prefetch" href = "/assets/cls.html.af39fd39.js" > < link rel = "prefetch" href = "/assets/commands.html.9dc0463a.js" > < link rel = "prefetch" href = "/assets/contact-us.html.16fb01ac.js" > < link rel = "prefetch" href = "/assets/dashboard.html.0b694615.js" > < link rel = "prefetch" href = "/assets/docker.html.797da397.js" > < link rel = "prefetch" href = "/assets/download.html.a75cd477.js" > < link rel = "prefetch" href = "/assets/dump.html.e5e17e0e.js" > < link rel = "prefetch" href = "/assets/echo.html.922d5af6.js" > < link rel = "prefetch" href = "/assets/faq.html.abd854f1.js" > < link rel = "prefetch" href = "/assets/getstatic.html.77a5a68e.js" > < link rel = "prefetch" href = "/assets/grep.html.75fa6737.js" > < link rel = "prefetch" href = "/assets/groovy.html.bcb88dfe.js" > < link rel = "prefetch" href = "/assets/heapdump.html.5e26a91c.js" > < link rel = "prefetch" href = "/assets/help.html.9365d9ca.js" > < link rel = "prefetch" href = "/assets/history.html.19b5039d.js" > < link rel = "prefetch" href = "/assets/http-api.html.1b6f4877.js" > < link rel = "prefetch" href = "/assets/idea-plugin.html.438f3f13.js" > < link rel = "prefetch" href = "/assets/install-detail.html.cfd3d763.js" > < link rel = "prefetch" href = "/assets/jad.html.45a48802.js" > < link rel = "prefetch" href = "/assets/jvm.html.9e2ef28b.js" > < link rel = "prefetch" href = "/assets/keymap.html.82e95f8e.js" > < link rel = "prefetch" href = "/assets/logger.html.38490b13.js" > < link rel = "prefetch" href = "/assets/manual-install.html.1daf5a51.js" > < link rel = "prefetch" href = "/assets/mbean.html.b5a19b16.js" > < link rel = "prefetch" href = "/assets/mc.html.28a839a5.js" > < link rel = "prefetch" href = "/assets/memory.html.21a8a665.js" > < link rel = "prefetch" href = "/assets/monitor.html.ea7499e3.js" > < link rel = "prefetch" href = "/assets/ognl.html.c55aa597.js" > < link rel = "prefetch" href = "/assets/options.html.da3ef3a3.js" > < link rel = "prefetch" href = "/assets/perfcounter.html.cfebcf2d.js" > < link rel = "prefetch" href = "/assets/pwd.html.9c92f559.js" > < link rel = "prefetch" href = "/assets/quick-start.html.d9abe6d7.js" > < link rel = "prefetch" href = "/assets/quit.html.3f89724d.js" > < link rel = "prefetch" href = "/assets/redefine.html.8a08813b.js" > < link rel = "prefetch" href = "/assets/release-notes.html.dc8ff1f0.js" > < link rel = "prefetch" href = "/assets/reset.html.1413086f.js" > < link rel = "prefetch" href = "/assets/retransform.html.342303bb.js" > < link rel = "prefetch" href = "/assets/save-log.html.c42ff748.js" > < link rel = "prefetch" href = "/assets/sc.html.f9c5b69c.js" > < link rel = "prefetch" href = "/assets/session.html.6904a40b.js" > < link rel = "prefetch" href = "/assets/sm.html.a212974a.js" > < link rel = "prefetch" href = "/assets/spring-boot-starter.html.e62a7a68.js" > < link rel = "prefetch" href = "/assets/stack.html.a3201354.js" > < link rel = "prefetch" href = "/assets/start-arthas.html.5421937d.js" > < link rel = "prefetch" href = "/assets/stop.html.e7556014.js" > < link rel = "prefetch" href = "/assets/sysenv.html.51ba409a.js" > < link rel = "prefetch" href = "/assets/sysprop.html.480d71dd.js" > < link rel = "prefetch" href = "/assets/tee.html.09a9aee7.js" > < link rel = "prefetch" href = "/assets/thread
< link rel = "stylesheet" href = "/assets/style.372e9f20.css" >
< / head >
< body >
< div id = "app" > <!-- [ --> < div class = "theme-container" > <!-- [ --> < header class = "navbar" > < div class = "toggle-sidebar-button" title = "切换侧边栏" aria-expanded = "false" role = "button" tabindex = "0" > < div class = "icon" aria-hidden = "true" > < span > < / span > < span > < / span > < span > < / span > < / div > < / div > < span > < a href = "/" class = "" data-v-2aa8cc94 > <!-- --> < span class = "site-name can-hide" data-v-2aa8cc94 > arthas< / span > < span class = "navbar-version" data-v-2aa8cc94 > v3.6.4< / span > < / a > < / span > < div class = "navbar-items-wrapper" style = "" > <!-- [ --> <!-- ] --> < nav class = "navbar-items can-hide" > <!-- [ --> < div class = "navbar-item" > < a href = "/" class = "" aria-label = "首页" > <!-- [ --> <!-- ] --> 首页 <!-- [ --> <!-- ] --> < / a > < / div > < div class = "navbar-item" > < a class = "external-link" href = "/doc/arthas-tutorials.html?language=cn&id=arthas-basics" rel = "noopener noreferrer" target = "_blank" aria-label = "在线教程" > <!-- [ --> <!-- ] --> < span > 在线教程< / span > < span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > <!-- [ --> <!-- ] --> < / a > < / div > < div class = "navbar-item" > < a href = "/doc/" class = "router-link-active" aria-label = "文档" > <!-- [ --> <!-- ] --> 文档 <!-- [ --> <!-- ] --> < / a > < / div > < div class = "navbar-item" > < div class = "navbar-dropdown-wrapper" > < button class = "navbar-dropdown-title" type = "button" aria-label = "解决方案" > < span class = "title" > 解决方案< / span > < span class = "arrow down" > < / span > < / button > < button class = "navbar-dropdown-title-mobile" type = "button" aria-label = "解决方案" > < span class = "title" > 解决方案< / span > < span class = "right arrow" > < / span > < / button > < ul style = "display:none;" class = "navbar-dropdown" > <!-- [ --> < li class = "navbar-dropdown-item" > < a class = "external-link" href = "https://cn.aliyun.com/product/aliware/mse?spm=arthas.topbar.0.0.0" rel = "noopener noreferrer" target = "_blank" aria-label = "微服务解决方案" > <!-- [ --> <!-- ] --> < span > 微服务解决方案< / span > < span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > <!-- [ --> <!-- ] --> < / a > < / li > < li class = "navbar-dropdown-item" > < a class = "external-link" href = "https://www.aliyun.com/aliware/txc?spm=arthas.topbar.0.0.0" rel = "noopener noreferrer" target = "_blank" aria-label = "分布式事务解决方案" > <!-- [ --> <!-- ] --> < span > 分布式事务解决方案< / span > < span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > <!-- [ --> <!-- ] --> < / a > < / li > < li class = "navbar-dropdown-item" > < a class = "external-link" href = "https://www.aliyun.com/product/ahas?spm=arthas.topbar.0.0.0" rel = "noopener noreferrer" target = "_blank" aria-label = "高可用解决方案" > <!-- [ --> <!-- ] --> < span > 高可用解决方案< / span > < span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewb
Started [cpu] profiling
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < div class = "custom-container tip" > < p class = "custom-container-title" > 提示< / p > < p > 默认情况下,生成的是 cpu 的火焰图,即 event 为< code > cpu< / code > 。可以用< code > --event< / code > 参数来指定。< / p > < / div > < h3 id = "获取已采集的-sample-的数量" tabindex = "-1" > < a class = "header-anchor" href = "#获取已采集的-sample-的数量" aria-hidden = "true" > #< / a > 获取已采集的 sample 的数量< / h3 > < div class = "language-text ext-text line-numbers-mode" > < pre class = "language-text" > < code > $ profiler getSamples
23
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < h3 id = "查看-profiler-状态" tabindex = "-1" > < a class = "header-anchor" href = "#查看-profiler-状态" aria-hidden = "true" > #< / a > 查看 profiler 状态< / h3 > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler status
< span class = "token punctuation" > [< / span > cpu< span class = "token punctuation" > ]< / span > profiling is running < span class = "token keyword" > for< / span > < span class = "token number" > 4< / span > seconds
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < p > 可以查看当前 profiler 在采样哪种< code > event< / code > 和采样时间。< / p > < h3 id = "停止-profiler" tabindex = "-1" > < a class = "header-anchor" href = "#停止-profiler" aria-hidden = "true" > #< / a > 停止 profiler< / h3 > < h4 id = "生成-html-格式结果" tabindex = "-1" > < a class = "header-anchor" href = "#生成-html-格式结果" aria-hidden = "true" > #< / a > 生成 html 格式结果< / h4 > < p > 默认情况下,结果文件是< code > html< / code > 格式,也可以用< code > --format< / code > 参数指定:< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler stop --format html
profiler output file: /tmp/test/arthas-output/20211207-111550.html
OK
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < p > 或者在< code > --file< / code > 参数里用文件名指名格式。比如< code > --file /tmp/result.html< / code > 。< / p > < h3 id = "通过浏览器查看-arthas-output-下面的-profiler-结果" tabindex = "-1" > < a class = "header-anchor" href = "#通过浏览器查看-arthas-output-下面的-profiler-结果" aria-hidden = "true" > #< / a > 通过浏览器查看 arthas-output 下面的 profiler 结果< / h3 > < p > 默认情况下, arthas 使用 3658 端口,则可以打开: < a href = "http://localhost:3658/arthas-output/" target = "_blank" rel = "noopener noreferrer" > http://localhost:3658/arthas-output/< span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > < / a > 查看到< code > arthas-output< / code > 目录下面的 profiler 结果:< / p > < p > < img src = "/images/arthas-output.jpg" alt = "" > < / p > < p > 点击可以查看具体的结果:< / p > < p > < img src = "/images/arthas-output-svg.jpg" alt = "" > < / p > < div class = "custom-container tip" > < p class = "custom-container-title" > 提示< / p > < p > 如果是 chrome 浏览器,可能需要多次刷新。< / p > < / div > < h3 id = "profiler-支持的-events" tabindex = "-1" > < a class = "header-anchor" href = "#profiler-支持的-events" aria-hidden = "true" > #< / a > profiler 支持的 events< / h3 > < p > 在不同的平台,不同的 OS 下面,支持的 events 各有不同。比如在 macos 下面:< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler list
Basic events:
cpu
alloc
lock
wall
itimer
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < p > 在 linux 下面< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler list
Basic events:
cpu
alloc
lock
wall
itimer
Perf events:
page-faults
context-switches
cycles
instructions
cache-references
cache-misses
branches
branch-misses
bus-cycles
L1-dcache-load-misses
LLC-load-misses
dTLB-load-misses
mem:breakpoint
trace:tracepoint
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < p > 如果遇到 OS 本身的权限/配置问题,然后 缺少部分 event, 可以参考< code > async-profiler< / code > 本身文档:< a href = "https://github.com/jvm-profiling-tools/async-profiler" target = "_blank" rel = "noopener noreferrer" > async-profiler< span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > < / a > < / p > < p > 可以用< code > --event< / code > 参数指定要采样的事件,比如对< code > alloc< / code > 事件进入采样:< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler start --event alloc
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < h3 id = "恢复采样" tabindex = "-1" > < a class = "header-anchor" href = "#恢复采样" aria-hidden = "true" > #< / a > 恢复采样< / h3 > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler resume
Started < span class = "token punctuation" > [< / span > cpu< span class = "token punctuation" > ]< / span > profiling
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < p > < code > start< / code > 和< code > resume< / code > 的区别是:< code > start< / code > 是新开始采样,< code > resume< / code > 会保留上次< code > stop< / code > 时的数据。< / p > < p > 通过执行< code > profiler getSamples< / code > 可以查看 samples 的数量来验证。< / p > < h3 id = "使用execute来执行复杂的命令" tabindex = "-1" > < a class = "header-anchor" href = "#使用execute来执行复杂的命令" aria-hidden = "true" > #< / a > 使用< code > execute< / code > 来执行复杂的命令< / h3 > < p > 比如开始采样:< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > profiler execute < span class = "token string" > ' start,framebuf=5000000' < / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < p > 停止采样,并保存到指定文件里:< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > profiler execute < span class = "token string" > ' stop,file=/tmp/result.html' < / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < p > 具体的格式参考: < a href = "https://github.com/jvm-profiling-tools/async-profiler/blob/v2.5/src/arguments.cpp#L50" target = "_blank" rel = "noopener noreferrer" > arguments.cpp< span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > < / a > < / p > < h3 id = "查看所有支持的-action" tabindex = "-1" > < a class = "header-anchor" href = "#查看所有支持的-action" aria-hidden = "true" > #< / a > 查看所有支持的 action< / h3 > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler actions
Supported Actions: < span class = "token punctuation" > [< / span > resume, dumpCollapsed, getSamples, start, list, execute, version, stop, load, dumpFlat, actions, dumpTraces, status< span class = "token punctuation" > ]< / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < h3 id = "查看版本" tabindex = "-1" > < a class = "header-anchor" href = "#查看版本" aria-hidden = "true" > #< / a > 查看版本< / h3 > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > $ profiler version
Async-profiler < span class = "token number" > 1.6< / span > built on Sep < span class = "token number" > 9< / span > < span class = "token number" > 2019< / span >
Copyright < span class = "token number" > 2019< / span > Andrei Pangin
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < h3 id = "配置-framebuf-参数" tabindex = "-1" > < a class = "header-anchor" href = "#配置-framebuf-参数" aria-hidden = "true" > #< / a > 配置 framebuf 参数< / h3 > < blockquote > < p > 如果遇到生成的火焰图有 < code > [frame_buffer_overflow]< / code > ,则需要增大 framebuf( 默认值是 1' 000' 000) , 可以显式配置, 比如: < / p > < / blockquote > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > profiler start --framebuf < span class = "token number" > 5000000< / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < h3 id = "配置-include-exclude-来过滤数据" tabindex = "-1" > < a class = "header-anchor" href = "#配置-include-exclude-来过滤数据" aria-hidden = "true" > #< / a > 配置 include/exclude 来过滤数据< / h3 > < p > 如果应用比较复杂,生成的内容很多,想只关注部分数据,可以通过 include/exclude 来过滤。比如< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > profiler start --include < span class = "token string" > ' java/*' < / span > --include < span class = "token string" > ' demo/*' < / span > --exclude < span class = "token string" > ' *Unsafe.park*' < / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < blockquote > < p > include/exclude 都支持设置多个值 ,但是需要配置在命令行的最后。< / p > < / blockquote > < h3 id = "指定执行时间" tabindex = "-1" > < a class = "header-anchor" href = "#指定执行时间" aria-hidden = "true" > #< / a > 指定执行时间< / h3 > < p > 比如,希望 profiler 执行 300 秒自动结束,可以用 < code > -d< / code > /< code > --duration< / code > 参数指定:< / p > < div class = "language-bash ext-sh line-numbers-mode" > < pre class = "language-bash" > < code > profiler start --duration < span class = "token number" > 300< / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < h3 id = "生成-jfr-格式结果" tabindex = "-1" > < a class = "header-anchor" href = "#生成-jfr-格式结果" aria-hidden = "true" > #< / a > 生成 jfr 格式结果< / h3 > < blockquote > < p > 注意, jfr 只支持在 < code > start< / code > 时配置。如果是在< code > stop< / code > 时指定,则不会生效。< / p > < / blockquote > < div class = "language-text ext-text line-numbers-mode" > < pre class = "language-text" > < code > profiler start --file /tmp/test.jfr
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < / div > < / div > < p > < code > file< / code > 参数支持一些变量:< / p > < ul > < li > 时间戳: < code > --file /tmp/test-%t.jfr< / code > < / li > < li > 进程 ID: < code > --file /tmp/test-%p.jfr< / code > < / li > < / ul > < p > 生成的结果可以用支持 jfr 格式的工具来查看。比如:< / p > < ul > < li > JDK Mission Control : https://github.com/openjdk/jmc< / li > < li > JProfiler : https://github.com/alibaba/arthas/issues/1416< / li > < / ul > < h3 id = "生成的火焰图里的-unknown" tabindex = "-1" > < a class = "header-anchor" href = "#生成的火焰图里的-unknown" aria-hidden = "true" > #< / a > 生成的火焰图里的 unknown< / h3 > < ul > < li > https://github.com/jvm-profiling-tools/async-profiler/discussions/409< / li > < / ul > < / div > <!-- [ --> <!-- ] --> < / div > < footer class = "page-meta right-menu-padding" data-v-e0e60120 > < div class = "meta-item edit-link" > < a class = "external-link meta-item-label" href = "https://github.com/alibaba/arthas/edit/master/site/docs/doc/profiler.md" rel = "noopener noreferrer" target = "_blank" aria-label = "在 GitHub 上编辑此页" > <!-- [ --> <!-- ] --> < span > 在 GitHub 上编辑此页< / span > < span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewbox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > 在新窗口打开< / span > < / span > <!-- [ --> <!-- ] --> < / a > < / div > < div class = "meta-item last-updated" > < span class = "meta-item-label" > Last Updated: < / span > <!-- --> < / div > < div class = "meta-item contributors" > < span class = "meta-item-label" > 贡献者: < / span > < span class = "meta-item-info" > <!-- [ --> <!-- [ --> < span class = "contributor" title = "email: hengyunabc@gmail.com" > hengyunabc< / span > <!-- [ --> , <!-- ] --> <!-- ] --> <!-- [ --> < span class = "contributor" title = "email: hollowman186@vip.qq.com" > Hollow Man< / span > <!-- --> <!-- ] --> <!-- ] --> < / span > < / div > < / footer > <!-- --> <!-- [ --> <!-- ] --> < / main > <!-- ] --> < / div > <!-- --> <!-- ] --> < / div >
< script type = "module" src = "/assets/app.bd2aade7.js" defer > < / script >
< / body >
< / html >