{"id":329,"date":"2025-07-30T00:03:51","date_gmt":"2025-07-29T16:03:51","guid":{"rendered":"http:\/\/yangnanbei.top\/?p=329"},"modified":"2025-08-03T22:37:15","modified_gmt":"2025-08-03T14:37:15","slug":"perf%e4%bb%8e%e5%85%a5%e9%97%a8%e5%88%b0maaaaaster","status":"publish","type":"post","link":"http:\/\/yangnanbei.top\/index.php\/2025\/07\/30\/perf%e4%bb%8e%e5%85%a5%e9%97%a8%e5%88%b0maaaaaster\/","title":{"rendered":"linux\u6027\u80fd\u5206\u6790\u5de5\u5177\u2014\u2014perf"},"content":{"rendered":"\n<p>Make tiny progress every day. \u2014\u2014yangnanbei<\/p>\n\n\n\n<p>\u53c2\u8003\u8d44\u6599\uff1a<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li>https:\/\/perf.wiki.kernel.org<\/li>\n\n\n\n<li>man\u624b\u518c<\/li>\n\n\n\n<li>https:\/\/www.youtube.com\/playlist?list=PLx-WakpEO8zFQGRrB4xYAuWjHKqVWlwaD<\/li>\n\n\n\n<li><a href=\"https:\/\/www.bilibili.com\/video\/BV1hK4y1A7U4\/?spm_id_from=333.337.search-card.all.click&amp;vd_source=29d4fa0f05c21737f4d2d377b8be842d\">Perf\u66f4\u8be6\u7ec6\u7684\u4ecb\u7ecd &#8211; \u9648\u5c0f\u6b27 &#8211; 20210512 &#8211; PLCT\u5b9e\u9a8c\u5ba4_\u54d4\u54e9\u54d4\u54e9_bilibili<\/a><\/li>\n\n\n\n<li>https:\/\/zhuanlan.zhihu.com\/p\/147875569<\/li>\n<\/ol>\n\n\n\n<h1 class=\"wp-block-heading\">\u524d\u8a00<\/h1>\n\n\n\n<p>\u8fd8\u8bb0\u5f97\u6211\u7b2c\u4e00\u4efd\u5de5\u4f5c\u521a\u5165\u804c\u5f00\u53d1\u7684\u7b2c\u4e00\u4e2a\u63a5\u53e3\uff0c\u5728\u7f51\u7edc\u6808\u5165\u53e3\u52a0\u4e86\u4e00\u4e2a\u5bf9\u4e8b\u4ef6A\u7684\u5904\u7406\u3002\u90a3\u65f6\u5019\u865a\u7ebf\u7684+1\u5f3a\u8c03\u8981\u6ce8\u610f\u8fd9\u4e00\u5757\u7684\u6027\u80fd\uff0c\u8fd8\u53cd\u590d\u4fee\u6539\u4e86\u51e0\u6b21\u3002\u90a3\u65f6\u6211\u95ee\u4e3a\u4ec0\u4e48\uff1f\u4ed6\u53ea\u8bf4\u8fd9\u662f\u5904\u7406\u94fe\u8def\u5fc5\u7ecf\u7684\u6d41\u7a0b\uff0c\u6240\u4ee5\u6027\u80fd\u8981\u7740\u91cd\u8003\u8651\u3002<\/p>\n\n\n\n<p>\u5b9e\u9645\u4e0a\uff0c\u7531\u201c\u5fc5\u7ecf\u94fe\u8def\u201d\u63a8\u51fa\u201c\u6027\u80fd\u5904\u7406\u91cd\u8981\u201d\u96be\u514d\u6709\u5c40\u90e8\u8fc7\u5ea6\u4f18\u5316\u7684\u5acc\u7591\u3002\u6027\u80fd\u95ee\u9898\u4e5f\u9075\u5faa<code>20\/80<\/code>\u539f\u5219\uff0c\u537380%\u7684\u6027\u80fd\u95ee\u9898\u662f\u753120%\u7684\u6027\u80fd\u4e0d\u53cb\u597d\u4ee3\u7801\u9020\u6210\u7684\uff0c\u5982\u4f55\u5b9a\u4f4d\u6027\u80fd\u4e0d\u53cb\u597d\u7684\u4ee3\u7801\u662f\u6027\u80fd\u5206\u6790\u4e2d\u5f88\u91cd\u8981\u7684\u8bfe\u9898\u3002<\/p>\n\n\n\n<p><code>perf<\/code>\u5de5\u5177\u6b63\u662f\u6211\u4eec\u5b9a\u4f4d\u6027\u80fd\u95ee\u9898\u7684\u597d\u5e2e\u624b\uff0c<code>perf<\/code> \u662f Linux \u7cfb\u7edf\u6027\u80fd\u5206\u6790\u548c\u4f18\u5316\u7684\u57fa\u77f3\u5de5\u5177\u3002\u5b83\u6700\u5927\u7684\u4ef7\u503c\u5728\u4e8e\u63d0\u4f9b\u4e86\u4e00\u4e2a\u9ad8\u6548\u3001\u4f4e\u5f00\u9500\u3001\u6df1\u5ea6\u96c6\u6210\u7684\u9014\u5f84\uff0c\u8ba9\u5f00\u53d1\u8005\u80fd\u591f\u8de8\u8d8a\u786c\u4ef6\u3001\u5185\u6838\u3001\u7528\u6237\u5e94\u7528\u7684\u754c\u9650\uff0c\u7cbe\u786e\u5730\u5b9a\u4f4d\u6027\u80fd\u74f6\u9888\u7684\u6839\u6e90\uff08\u7cbe\u786e\u5230\u51fd\u6570\u3001\u6e90\u7801\u884c\u751a\u81f3\u6307\u4ee4\uff09\u3002\u65e0\u8bba\u662f\u8fdb\u884c\u5fae\u89c2\u7684\u4ee3\u7801\u4f18\u5316\uff0c\u8fd8\u662f\u8bca\u65ad\u5b8f\u89c2\u7684\u7cfb\u7edf\u7ea7\u95ee\u9898\uff0c<code>perf<\/code> \u90fd\u662f\u4e0d\u53ef\u6216\u7f3a\u7684\u5229\u5668\u3002\u638c\u63e1 <code>perf<\/code> \u662f Linux \u5f00\u53d1\u8005\u548c\u6027\u80fd\u5de5\u7a0b\u5e08\u7684\u6838\u5fc3\u6280\u80fd\u4e4b\u4e00\u3002<\/p>\n\n\n\n<p>\u8ba9\u6211\u4eec\u8bf7<strong>\u5927D\u8001\u5e08<\/strong>\u4ecb\u7ecd\u4e00\u4e0bperf\u5427\uff1a<\/p>\n\n\n\n<p>\u4f7f\u7528 <code>perf<\/code> \u7684\u80cc\u666f\/\u539f\u56e0\uff1a<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li>\u5185\u6838\u96c6\u6210\uff1a \u4f5c\u4e3a\u5185\u6838\u7684\u4e00\u90e8\u5206\uff08\u901a\u8fc7 <code>perf_event_open<\/code> \u7cfb\u7edf\u8c03\u7528\uff09\uff0c<code>perf<\/code> \u5177\u6709\u6781\u9ad8\u7684\u6743\u9650\u548c\u4f4e\u5f00\u9500\uff0c\u80fd\u8bbf\u95ee\u5e95\u5c42\u786c\u4ef6\u8ba1\u6570\u5668\u548c\u5185\u6838\u5185\u90e8\u72b6\u6001\u3002<\/li>\n\n\n\n<li>\u66ff\u4ee3\u4f20\u7edf\u5de5\u5177\uff1a \u5b83\u6574\u5408\u5e76\u8d85\u8d8a\u4e86\u4e4b\u524d\u5206\u6563\u7684\u5de5\u5177\u5982 <code>oprofile<\/code>\u3001<code>ptrace<\/code> \u7684\u90e8\u5206\u529f\u80fd\uff0c\u63d0\u4f9b\u4e86\u66f4\u7edf\u4e00\u3001\u9ad8\u6548\u7684\u754c\u9762\u3002<\/li>\n\n\n\n<li>\u786c\u4ef6\u652f\u6301\uff1a \u76f4\u63a5\u5229\u7528 CPU\uff08Intel \u7684 PMU, AMD \u7684 IBS, ARM \u7684 PMU \u7b49\uff09\u63d0\u4f9b\u7684\u786c\u4ef6\u6027\u80fd\u8ba1\u6570\u5668\uff0c\u7cbe\u786e\u6d4b\u91cf\u5982 CPU \u5468\u671f\u3001\u6307\u4ee4\u6570\u3001\u7f13\u5b58\u547d\u4e2d\/\u5931\u6548\u3001\u5206\u652f\u9884\u6d4b\u9519\u8bef\u7b49\u5e95\u5c42\u786c\u4ef6\u4e8b\u4ef6\u3002<\/li>\n\n\n\n<li>\u8f6f\u4ef6\u62bd\u8c61\uff1a \u9664\u4e86\u786c\u4ef6\u4e8b\u4ef6\uff0c\u8fd8\u80fd\u8bbf\u95ee\u8f6f\u4ef6\u4e8b\u4ef6\uff08\u5982\u9875\u9762\u9519\u8bef\u3001\u4e0a\u4e0b\u6587\u5207\u6362\u3001\u8c03\u5ea6\u4e8b\u4ef6\uff09\u548c\u8ddf\u8e2a\u70b9\uff08\u5185\u6838\u4e2d\u9884\u5b9a\u4e49\u7684\u9759\u6001\u63a2\u6d4b\u70b9\uff09\u4ee5\u53ca\u52a8\u6001\u63a2\u9488\uff08kprobes, uprobes\uff09\u3002<\/li>\n\n\n\n<li>\u89e3\u51b3\u6027\u80fd\u75db\u70b9\uff1a \u5728\u590d\u6742\u7684\u73b0\u4ee3\u7cfb\u7edf\uff08\u591a\u6838\u3001\u8d85\u7ebf\u7a0b\u3001NUMA\u3001\u590d\u6742\u8f6f\u4ef6\u6808\uff09\u4e2d\u5b9a\u4f4d\u6027\u80fd\u74f6\u9888\uff08CPU\u3001\u5185\u5b58\u3001I\/O\u3001\u9501\u4e89\u7528\u7b49\uff09\u975e\u5e38\u56f0\u96be\uff0c\u9700\u8981\u6df1\u5165\u4e14\u5168\u9762\u7684\u5de5\u5177\u3002<\/li>\n<\/ol>\n\n\n\n<p>\u4f7f\u7528 <code>perf<\/code> \u7684\u4e3b\u8981\u597d\u5904\uff1a<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li>\u529f\u80fd\u5168\u9762\uff08One Tool to Rule Them All\uff09\uff1a\n<ol class=\"wp-block-list\">\n<li>CPU \u5206\u6790\uff1a \u5206\u6790\u70ed\u70b9\u51fd\u6570\u3001\u6307\u4ee4\u7ea7\u5f00\u9500\u3001CPI \u7b49\u3002<\/li>\n\n\n\n<li>\u7f13\u5b58\u5206\u6790\uff1a \u5b9a\u4f4d\u7f13\u5b58\u672a\u547d\u4e2d\uff08L1\/L2\/L3 dTLB\/iTLB\uff09\u7684\u4ee3\u7801\u4f4d\u7f6e\u3002<\/li>\n\n\n\n<li>\u5185\u5b58\u5206\u6790\uff1a \u5206\u6790\u5185\u5b58\u8bbf\u95ee\u6a21\u5f0f\u3001\u5e26\u5bbd\u3001\u7f3a\u9875\u5f02\u5e38\u3002<\/li>\n\n\n\n<li>I\/O \u5206\u6790\uff1a \u8ddf\u8e2a\u5757\u8bbe\u5907 I\/O\u3001\u540c\u6b65\u5f00\u9500\uff08\u867d\u7136\u4e0d\u5982 <code>bpftrace<\/code>\/<code>eBPF<\/code> \u7075\u6d3b\uff0c\u4f46\u57fa\u7840\u652f\u6301\uff09\u3002<\/li>\n\n\n\n<li>\u8c03\u5ea6\u5206\u6790\uff1a \u5206\u6790\u4e0a\u4e0b\u6587\u5207\u6362\u3001CPU \u8fc1\u79fb\u3001\u8d1f\u8f7d\u5747\u8861\u95ee\u9898\u3001\u8c03\u5ea6\u5ef6\u8fdf\u3002<\/li>\n\n\n\n<li>\u9501\u5206\u6790\uff1a \u68c0\u6d4b\u9501\u4e89\u7528\u3001\u81ea\u65cb\u9501\u6301\u6709\u65f6\u95f4\u3002<\/li>\n\n\n\n<li>\u8c03\u7528\u94fe\u5206\u6790\uff1a \u8bb0\u5f55\u5e76\u53ef\u89c6\u5316\u51fd\u6570\u8c03\u7528\u5173\u7cfb\uff08stack traces\uff09\u3002<\/li>\n\n\n\n<li>\u8ddf\u8e2a\uff1a \u8bb0\u5f55\u5185\u6838\u548c\u7528\u6237\u7a7a\u95f4\u7279\u5b9a\u4e8b\u4ef6\u7684\u53d1\u751f\u5e8f\u5217\uff08<code>perf record -e tracepoint<\/code>\uff09\u3002<\/li>\n\n\n\n<li>\u9759\u6001\/\u52a8\u6001\u63a2\u9488\uff1a \u5728\u51fd\u6570\u5165\u53e3\/\u51fa\u53e3\u6216\u4efb\u610f\u6307\u4ee4\u5904\u63d2\u5165\u63a2\u6d4b\u70b9\u6536\u96c6\u6570\u636e\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u4f4e\u5f00\u9500\uff1a\n<ol class=\"wp-block-list\">\n<li>\u5229\u7528\u786c\u4ef6\u8ba1\u6570\u5668\u8fdb\u884c\u91c7\u6837\uff0c\u5f00\u9500\u901a\u5e38\u5f88\u4f4e\uff08\u5c24\u5176\u662f\u91c7\u6837\u6a21\u5f0f\uff09\uff0c\u9002\u5408\u751f\u4ea7\u73af\u5883\u4f7f\u7528\u3002<\/li>\n\n\n\n<li>\u5185\u6838\u7ea7\u5b9e\u73b0\u907f\u514d\u4e86\u9891\u7e41\u7684\u7528\u6237\/\u5185\u6838\u6001\u5207\u6362\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u6df1\u5ea6\u6d1e\u5bdf\uff08\u4ece\u786c\u4ef6\u5230\u5e94\u7528\uff09\uff1a\n<ol class=\"wp-block-list\">\n<li>\u8de8\u8d8a\u5c42\u7ea7\uff1a \u80fd\u5c06\u786c\u4ef6\u4e8b\u4ef6\uff08\u5982\u7f13\u5b58\u672a\u547d\u4e2d\uff09\u76f4\u63a5\u5173\u8054\u5230\u7279\u5b9a\u7684\u5185\u6838\u51fd\u6570\u751a\u81f3\u7528\u6237\u7a7a\u95f4\u7684\u4ee3\u7801\u884c\u6216\u6307\u4ee4\u3002\u8fd9\u662f\u5176\u6700\u5f3a\u5927\u7684\u4f18\u52bf\u4e4b\u4e00\u3002<\/li>\n\n\n\n<li>\u7cbe\u786e\u5230\u6307\u4ee4\/\u6e90\u7801\u884c\uff1a \u7ed3\u5408\u8c03\u8bd5\u4fe1\u606f\uff08<code>-g<\/code>\uff09\uff0c\u53ef\u4ee5\u5c06\u6027\u80fd\u4e8b\u4ef6\u5b9a\u4f4d\u5230\u6e90\u4ee3\u7801\u884c\u6216\u6c47\u7f16\u6307\u4ee4\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u751f\u4ea7\u73af\u5883\u53cb\u597d\uff1a\n<ol class=\"wp-block-list\">\n<li>\u4f4e\u5f00\u9500\u4f7f\u5176\u80fd\u591f\u5728\u771f\u5b9e\u8d1f\u8f7d\u4e0b\u8fd0\u884c\uff0c\u6355\u83b7\u5b9e\u9645\u751f\u4ea7\u73af\u5883\u4e2d\u7684\u95ee\u9898\uff0c\u800c\u4e0d\u4ec5\u4ec5\u662f\u5728\u6d4b\u8bd5\u73af\u5883\u4e2d\u3002<\/li>\n\n\n\n<li>\u4e0d\u9700\u8981\u4fee\u6539\u6216\u91cd\u542f\u5e94\u7528\u7a0b\u5e8f\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u4e30\u5bcc\u7684\u62a5\u544a\u548c\u53ef\u89c6\u5316\uff1a\n<ol class=\"wp-block-list\">\n<li><code>perf report<\/code>\uff1a \u4ea4\u4e92\u5f0f\u67e5\u770b\u91c7\u6837\u7ed3\u679c\uff0c\u6309\u51fd\u6570\u3001\u6e90\u7801\u884c\u3001\u6307\u4ee4\u6392\u5e8f\u70ed\u70b9\u3002<\/li>\n\n\n\n<li><code>perf annotate<\/code>\uff1a \u5c06\u6c47\u7f16\u6307\u4ee4\u6216\u6e90\u7801\u884c\u4e0e\u4e8b\u4ef6\u8ba1\u6570\u5173\u8054\u663e\u793a\u3002<\/li>\n\n\n\n<li><code>perf script<\/code>\uff1a \u5bfc\u51fa\u539f\u59cb\u6570\u636e\u4f9b\u81ea\u5b9a\u4e49\u811a\u672c\u5206\u6790\uff08\u5982\u751f\u6210\u706b\u7130\u56fe\uff09\u3002<\/li>\n\n\n\n<li>\u706b\u7130\u56fe\uff1a <code>perf<\/code> \u6570\u636e\u662f\u751f\u6210 CPU\u3001\u5185\u5b58\u706b\u7130\u56fe\uff08FlameGraph\uff09\u7684\u6807\u51c6\u8f93\u5165\u6765\u6e90\uff0c\u63d0\u4f9b\u76f4\u89c2\u7684\u6027\u80fd\u74f6\u9888\u53ef\u89c6\u5316\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u5f3a\u5927\u7684\u7edf\u8ba1\u529f\u80fd\uff1a\n<ol class=\"wp-block-list\">\n<li><code>perf stat<\/code>\uff1a \u5feb\u901f\u8fd0\u884c\u4e00\u4e2a\u547d\u4ee4\u5e76\u6c47\u603b\u6574\u4e2a\u6267\u884c\u8fc7\u7a0b\u4e2d\u7684\u5404\u79cd\u786c\u4ef6\/\u8f6f\u4ef6\u4e8b\u4ef6\u8ba1\u6570\uff0c\u63d0\u4f9b\u5b8f\u89c2\u6027\u80fd\u6307\u6807\uff08\u5982 IPC &#8211; Instructions Per Cycle\uff09\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u6d3b\u8dc3\u7684\u793e\u533a\u548c\u751f\u6001\u7cfb\u7edf\uff1a\n<ol class=\"wp-block-list\">\n<li>\u4f5c\u4e3a Linux \u5185\u6838\u7684\u4e00\u90e8\u5206\uff0c\u6301\u7eed\u66f4\u65b0\uff0c\u652f\u6301\u65b0\u786c\u4ef6\u548c\u65b0\u7279\u6027\u3002<\/li>\n\n\n\n<li>\u6709\u5927\u91cf\u7684\u6559\u7a0b\u3001\u535a\u5ba2\u6587\u7ae0\u3001\u6848\u4f8b\u5206\u6790\u548c\u5de5\u5177\uff08\u5982\u706b\u7130\u56fe\u751f\u6210\u811a\u672c\uff09\u56f4\u7ed5\u5b83\u5c55\u5f00\u3002<\/li>\n<\/ol>\n<\/li>\n\n\n\n<li>\u76f8\u5bf9\u6613\u7528\u6027\uff08\u76f8\u6bd4\u66f4\u5e95\u5c42\u7684\u5de5\u5177\uff09\uff1a\n<ol class=\"wp-block-list\">\n<li>\u63d0\u4f9b\u4e86\u76f8\u5bf9\u9ad8\u7ea7\u7684\u547d\u4ee4\u884c\u63a5\u53e3\uff0c\u62bd\u8c61\u4e86\u5e95\u5c42\u786c\u4ef6\u7684\u590d\u6742\u6027\u3002<\/li>\n\n\n\n<li>\u5e38\u7528\u573a\u666f\uff08\u5982 CPU \u70ed\u70b9\u5206\u6790\uff09\u7684\u547d\u4ee4\uff08<code>perf record<\/code>, <code>perf report<\/code>\uff09\u5b66\u4e60\u66f2\u7ebf\u76f8\u5bf9\u5e73\u7f13\u3002<\/li>\n<\/ol>\n<\/li>\n<\/ol>\n\n\n\n<h1 class=\"wp-block-heading\">\u547d\u4ee4<\/h1>\n\n\n\n<p>\u4e3b\u5305\u5728wsl\u73af\u5883\u5b9e\u9a8c\uff0c\u90e8\u5206\u786c\u4ef6\u8ba1\u6570\u65e0\u6cd5\u91c7\u96c6\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">perf list<\/h2>\n\n\n\n<p>\u663e\u793a\u5f53\u4e0b\u73af\u5883perf\u652f\u6301\u7684trace point<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#f6f6f4;--cbp-line-number-width:calc(2 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#282A36\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#f6f6f4;display:none\" aria-label=\"\u590d\u5236\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>perf list\nList of pre-defined events (to be used in -e or -M):\n\n  alignment-faults                                   &#91;Software event&#93;\n  bpf-output                                         &#91;Software event&#93;\n  cgroup-switches                                    &#91;Software event&#93;\n  context-switches OR cs                             &#91;Software event&#93;\n  cpu-clock                                          &#91;Software event&#93;\n  cpu-migrations OR migrations                       &#91;Software event&#93;\n  dummy                                              &#91;Software event&#93;\n  emulation-faults                                   &#91;Software event&#93;\n  major-faults                                       &#91;Software event&#93;\n  minor-faults                                       &#91;Software event&#93;\n  page-faults OR faults                              &#91;Software event&#93;\n  task-clock                                         &#91;Software event&#93;\n\ntool:\n  duration_time\n  user_time\n  system_time\n  msr\/pperf\/                                         &#91;Kernel PMU event&#93;\n  msr\/smi\/                                           &#91;Kernel PMU event&#93;\n  msr\/tsc\/                                           &#91;Kernel PMU event&#93;\n  rNNN                                               &#91;Raw hardware event descriptor&#93;\n  ...<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M16.5 8.25V6a2.25 2.25 0 00-2.25-2.25H6A2.25 2.25 0 003.75 6v8.25A2.25 2.25 0 006 16.5h2.25m8.25-8.25H18a2.25 2.25 0 012.25 2.25V18A2.25 2.25 0 0118 20.25h-7.5A2.25 2.25 0 018.25 18v-1.5m8.25-8.25h-6a2.25 2.25 0 00-2.25 2.25v6\"><\/path><\/svg><\/span><pre class=\"shiki dracula-soft\" style=\"background-color: #282A36\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #62E884\">perf<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">list<\/span><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">List<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">of<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">pre-defined<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">events<\/span><span style=\"color: #F6F6F4\"> (to <\/span><span style=\"color: #E7EE98\">be<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">used<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">in<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-e<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">or<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-M<\/span><span style=\"color: #F6F6F4\">):<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">alignment-faults<\/span><span style=\"color: #F6F6F4\">                                   &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">bpf-output<\/span><span style=\"color: #F6F6F4\">                                         &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">cgroup-switches<\/span><span style=\"color: #F6F6F4\">                                    &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">context-switches<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">OR<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">cs<\/span><span style=\"color: #F6F6F4\">                             &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">cpu-clock<\/span><span style=\"color: #F6F6F4\">                                          &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">cpu-migrations<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">OR<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">migrations<\/span><span style=\"color: #F6F6F4\">                       &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">dummy<\/span><span style=\"color: #F6F6F4\">                                              &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">emulation-faults<\/span><span style=\"color: #F6F6F4\">                                   &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">major-faults<\/span><span style=\"color: #F6F6F4\">                                       &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">minor-faults<\/span><span style=\"color: #F6F6F4\">                                       &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">page-faults<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">OR<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">faults<\/span><span style=\"color: #F6F6F4\">                              &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">task-clock<\/span><span style=\"color: #F6F6F4\">                                         &#91;Software <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">tool:<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">duration_time<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">user_time<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">system_time<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">msr\/pperf\/<\/span><span style=\"color: #F6F6F4\">                                         &#91;Kernel <\/span><span style=\"color: #E7EE98\">PMU<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">msr\/smi\/<\/span><span style=\"color: #F6F6F4\">                                           &#91;Kernel <\/span><span style=\"color: #E7EE98\">PMU<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">msr\/tsc\/<\/span><span style=\"color: #F6F6F4\">                                           &#91;Kernel <\/span><span style=\"color: #E7EE98\">PMU<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">event&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #62E884\">rNNN<\/span><span style=\"color: #F6F6F4\">                                               &#91;Raw <\/span><span style=\"color: #E7EE98\">hardware<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">event<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">descriptor&#93;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">  <\/span><span style=\"color: #97E1F1\">...<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u7edf\u8ba1\u5206\u7c7b<\/h3>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf list | awk -F: &#8216;\/Tracepoint event\/ { lib[$1]++ } END {<\/p>\n\n\n\n<p>for (l in lib) {printf &#8221; %-16.16s %d\\n&#8221;, l, lib[l] } } &#8216; | sort | column<\/p>\n<\/blockquote>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-22-1024x353.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"353\" data-original=\"http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-22-1024x353.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-341\"  sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Syscalls: syscall enter and exit<\/li>\n\n\n\n<li>Ext4: file system events<\/li>\n\n\n\n<li>Block: block device event<\/li>\n\n\n\n<li>Sock: socket event<\/li>\n\n\n\n<li>Sched: cpu schedule<\/li>\n\n\n\n<li>Kmem: kernel memery event<\/li>\n<\/ul>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-21.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"564\" height=\"317\" data-original=\"http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-21.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-340\"  sizes=\"(max-width: 564px) 100vw, 564px\" \/><\/div><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">perf stat<\/h2>\n\n\n\n<p>\u7edf\u8ba1\u4e8b\u4ef6\u8ba1\u6570<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#f6f6f4;--cbp-line-number-width:calc(2 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#282A36\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#f6f6f4;display:none\" aria-label=\"\u590d\u5236\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>perf stat -h\n\n usage: perf stat &#91;&lt;options>&#93; &#91;&lt;command>&#93;\n\n    -e, --event &lt;event>   event selector. use 'perf list' to list available events\n    -i, --no-inherit      child tasks do not inherit counters\n    -p, --pid &lt;n>         stat events on existing process id\n    -t, --tid &lt;n>         stat events on existing thread id\n    -a, --all-cpus        system-wide collection from all CPUs\n    -c, --scale           scale\/normalize counters\n    -v, --verbose         be more verbose (show counter open errors, etc)\n    -r, --repeat &lt;n>      repeat command and print average + stddev (max: 100)\n    -n, --null            null run - dont start any counters\n    -B, --big-num         print large numbers with thousands' separators<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M16.5 8.25V6a2.25 2.25 0 00-2.25-2.25H6A2.25 2.25 0 003.75 6v8.25A2.25 2.25 0 006 16.5h2.25m8.25-8.25H18a2.25 2.25 0 012.25 2.25V18A2.25 2.25 0 0118 20.25h-7.5A2.25 2.25 0 018.25 18v-1.5m8.25-8.25h-6a2.25 2.25 0 00-2.25 2.25v6\"><\/path><\/svg><\/span><pre class=\"shiki dracula-soft\" style=\"background-color: #282A36\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #62E884\">perf<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">stat<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-h<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #62E884\">usage:<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">perf<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">stat<\/span><span style=\"color: #F6F6F4\"> &#91;&lt;options&gt;&#93; &#91;<\/span><span style=\"color: #F286C4\">&lt;<\/span><span style=\"color: #F6F6F4\">command<\/span><span style=\"color: #F286C4\">&gt;<\/span><span style=\"color: #F6F6F4\">&#93;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-e,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--event<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #F286C4\">&lt;<\/span><span style=\"color: #E7EE98\">even<\/span><span style=\"color: #F6F6F4\">t<\/span><span style=\"color: #F286C4\">&gt;<\/span><span style=\"color: #F6F6F4\">   <\/span><span style=\"color: #E7EE98\">event<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">selector.<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">use<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #DEE492\">&#39;<\/span><span style=\"color: #E7EE98\">perf list<\/span><span style=\"color: #DEE492\">&#39;<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">to<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">list<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">available<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">events<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-i,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--no-inherit<\/span><span style=\"color: #F6F6F4\">      <\/span><span style=\"color: #E7EE98\">child<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">tasks<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">do<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">not<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">inherit<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">counters<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-p,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--pid<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #F286C4\">&lt;<\/span><span style=\"color: #F6F6F4\">n<\/span><span style=\"color: #F286C4\">&gt;<\/span><span style=\"color: #F6F6F4\">         <\/span><span style=\"color: #E7EE98\">stat<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">events<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">on<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">existing<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">process<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">id<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-t,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--tid<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #F286C4\">&lt;<\/span><span style=\"color: #F6F6F4\">n<\/span><span style=\"color: #F286C4\">&gt;<\/span><span style=\"color: #F6F6F4\">         <\/span><span style=\"color: #E7EE98\">stat<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">events<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">on<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">existing<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">thread<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">id<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-a,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--all-cpus<\/span><span style=\"color: #F6F6F4\">        <\/span><span style=\"color: #E7EE98\">system-wide<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">collection<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">from<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">all<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">CPUs<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-c,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--scale<\/span><span style=\"color: #F6F6F4\">           <\/span><span style=\"color: #E7EE98\">scale\/normalize<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">counters<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-v,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--verbose<\/span><span style=\"color: #F6F6F4\">         <\/span><span style=\"color: #E7EE98\">be<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">more<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">verbose<\/span><span style=\"color: #F6F6F4\"> (show <\/span><span style=\"color: #E7EE98\">counter<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">open<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">errors,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">etc<\/span><span style=\"color: #F6F6F4\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-r,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--repeat<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #F286C4\">&lt;<\/span><span style=\"color: #F6F6F4\">n<\/span><span style=\"color: #F286C4\">&gt;<\/span><span style=\"color: #F6F6F4\">      <\/span><span style=\"color: #E7EE98\">repeat<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">command<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">and<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">print<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">average<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">+<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">stddev<\/span><span style=\"color: #F6F6F4\"> (max: <\/span><span style=\"color: #BF9EEE\">100<\/span><span style=\"color: #F6F6F4\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-n,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--null<\/span><span style=\"color: #F6F6F4\">            <\/span><span style=\"color: #E7EE98\">null<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">run<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">-<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">dont<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">start<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">any<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">counters<\/span><\/span>\n<span class=\"line\"><span style=\"color: #F6F6F4\">    <\/span><span style=\"color: #62E884\">-B,<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--big-num<\/span><span style=\"color: #F6F6F4\">         <\/span><span style=\"color: #E7EE98\">print<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">large<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">numbers<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">with<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">thousands<\/span><span style=\"color: #DEE492\">&#39;<\/span><span style=\"color: #E7EE98\"> separators<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<p>\u6211\u4eec\u53ef\u4ee5\u9009\u62e9\u60f3\u8981\u7edf\u8ba1\u7684\u4e8b\u4ef6\u7c7b\u578b<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e cycles dd if=\/dev\/zero of=\/dev\/null count=100000<\/p>\n<\/blockquote>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u9ed8\u8ba4\u7edf\u8ba1\u7528\u6237\u6001\u548c\u5185\u6838\u6001<\/li>\n<\/ul>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e cycles:u dd if=\/dev\/zero of=\/dev\/null count=100000<\/p>\n<\/blockquote>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u53ea\u7edf\u8ba1\u7528\u6237\u6001<\/li>\n<\/ul>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e cycles:uk dd if=\/dev\/zero of=\/dev\/null count=100000<\/p>\n<\/blockquote>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u663e\u793a\u6307\u5b9a\u7edf\u8ba1 \u7528\u6237\u6001+\u5185\u6838\u6001<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">\u6bcf1s\u7edf\u8ba1\u4e00\u6b21<\/h3>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -a -I 1000 &#8212; sleep 3<\/p>\n<\/blockquote>\n\n\n\n<ul class=\"wp-block-list\">\n<li>-I 1000\uff1a\u6bcf1000ms\u7edf\u8ba1\u4e00\u6b21<\/li>\n<\/ul>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-7-1024x431.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"431\" data-original=\"http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-7-1024x431.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-339\"  sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">\u7edf\u8ba1\u7279\u5b9a\u4e8b\u4ef6<\/h3>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e cycles,instructions,cache-misses [&#8230;]<\/p>\n<\/blockquote>\n\n\n\n<p>\u6211\u4eec\u53ef\u4ee5\u7edf\u8ba1\u67d0\u4e2a\u4e8b\u4ef6\uff0c\u6216\u8005\u7279\u5b9a\u4e8b\u4ef6<\/p>\n\n\n\n<p>\u53ef\u4ee5\u91cd\u590d\u8fd0\u884c\u591a\u6b21<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e cache-misses -r 5 sleep 1<\/p>\n<\/blockquote>\n\n\n\n<p>\u53ef\u4ee5\u7528\u901a\u914d\u7b26\u5339\u914d\u7279\u5b9a\u4e8b\u4ef6<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e &#8216;syscalls:sys_enter_*&#8217; -C 1 &#8212; sleep 1<\/p>\n<\/blockquote>\n\n\n\n<p>\u5339\u914d\u540e\u8fc7\u6ee4 \u6b21\u6570\u4e0d\u4e3a0\u7684\u4e8b\u4ef6<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e &#8216;syscalls:sys_enter_*&#8217; -C 1 &#8212; sleep 1 2&gt;&amp;1 | awk &#8216;$1 != 0&#8217;<\/p>\n<\/blockquote>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-6.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"974\" height=\"389\" data-original=\"http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-6.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-338\"  sizes=\"(max-width: 974px) 100vw, 974px\" \/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">\u7edf\u8ba1\u7279\u5b9a\u6838<\/h3>\n\n\n\n<p>\u9ad8\u6027\u80fd\u8fdb\u7a0b\u7684\u6570\u636e\u9762\u7ebf\u7a0b\u5f80\u5f80\u662f\u7ed1\u5b9a\u4e14\u72ec\u5360\u7279\u5b9a\u7684cpu\u6838\uff0c\u6211\u4eec\u53ef\u4ee5\u7edf\u8ba1\u67d0\u4e2a\/\u67d0\u4e9b\u6838\u7684\u7279\u5b9a\u4e8b\u4ef6\u6280\u672f<\/p>\n\n\n\n<p>\u5982\uff1a<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -B -e cycles:u,instructions:u -a -C 0,2-3 sleep 5<\/p>\n<\/blockquote>\n\n\n\n<h3 class=\"wp-block-heading\">PMU raw counter<\/h3>\n\n\n\n<p>\u8fd8\u53ef\u4ee5\u7edf\u8ba1\u4e00\u4e9bCPU\u6027\u80fd\u76d1\u63a7<strong>(PMU, Performance Monitoring Unit)<\/strong>\u4e8b\u4ef6<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf stat -e r003c -a sleep 1<\/p>\n<\/blockquote>\n\n\n\n<p>\u5982 003C\uff1a UnHalted Core Cycles<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-5.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"572\" height=\"184\" data-original=\"http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-5.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-337\"  sizes=\"(max-width: 572px) 100vw, 572px\" \/><\/div><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">perf trace<\/h2>\n\n\n\n<p>\u8ddf\u8e2a\u4e8b\u4ef6<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u8ddf\u8e2a\u67d0\u4e2a\u6838\u4e0a\u7684\u9501\u4e8b\u4ef6<\/h3>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf trace -e futex -C 2<\/p>\n<\/blockquote>\n\n\n\n<h2 class=\"wp-block-heading\">perf record<\/h2>\n\n\n\n<p>\u91c7\u6837\u4e8b\u4ef6\u4ee5\u4f9b\u5206\u6790<\/p>\n\n\n\n<p>\u5bf9\u4e8e\u4e8b\u4ef6\u53ef\u5206\u6790\u7684\u6570\u636e\u6bd4\u8d77stat\u66f4\u8be6\u7ec6\uff0c\u53ef\u4ee5\u8ddf\u8e2a\u5806\u6808<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf record -e block:block_rq_complete -a sleep 2<\/p>\n<\/blockquote>\n\n\n\n<h3 class=\"wp-block-heading\">perf script<\/h3>\n\n\n\n<p>\u5c55\u793arecord\u7684\u4fe1\u606f<\/p>\n\n\n\n<p>\u5982<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>perf record -e block:block_rq_complete -a sleep 2<\/p>\n<\/blockquote>\n\n\n\n<p>\u91c7\u6837\u7ed3\u675f\u540e\u4f7f\u7528perf script<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-4-1024x244.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"244\" data-original=\"http:\/\/yangnanbei.top\/wp-content\/uploads\/2025\/07\/image-4-1024x244.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-336\"  sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<p>\u4ee5\u4e0a\u6bcf\u5217\u5206\u522b\u4ee3\u8868<\/p>\n\n\n\n<p>command, pid, cpuid, timestamp, event name, storage device major and minor number, type of I\/O, block command details, storage device offset + sizeof I\/O, errors.<\/p>\n\n\n\n<p>\u4ee5\u4e0a\u662f\u901a\u8fc7\u7ecf\u9a8c\u5bf9\u7167\u5f97\u6765\u7684\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528-F\u53c2\u6570\u6765\u6307\u5b9a\u60f3\u8981display\u7684\u5217\uff08man perf-script\uff09\u3002<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>-F, &#8211;fields<\/p>\n\n\n\n<p>Comma separated list of fields to print. Options are: comm, tid, pid, time, cpu, event, trace, ip, sym,<\/p>\n\n\n\n<p>dso, dsoff, addr, symoff, srcline, period, iregs, uregs, brstack, brstacksym, flags, bpf-output,<\/p>\n\n\n\n<p>brstackinsn, brstackinsnlen, brstackoff, callindent, insn, insnlen, synth, phys_addr, metric, misc,<\/p>\n\n\n\n<p>srccode, ipc, data_page_size, code_page_size, ins_lat, machine_pid, vcpu, cgroup, retire_lat. Field list<\/p>\n\n\n\n<p>can be prepended with the type, trace, sw or hw, to indicate to which event type the field list applies.<\/p>\n\n\n\n<p>e.g., -F sw:comm,tid,time,ip,sym and -F trace:time,cpu,trace<\/p>\n<\/blockquote>\n\n\n\n<h2 class=\"wp-block-heading\">perf top<\/h2>\n\n\n\n<p>\u5b9e\u65f6\u52a8\u6001\u8ddf\u8e2a\u4e8b\u4ef6<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">perf report<\/h2>\n\n\n\n<p>\u6574\u7406\u62a5\u544a\uff0c\u5c06\u8bb0\u5f55\u7684\u62a5\u544a\u6574\u7406\u6210\u8fdb\u7a0b\uff0c\u4e8b\u4ef6\uff0c\u5806\u6808\u7b49<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">perf bench<\/h2>\n\n\n\n<p>\u8dd1\u6d4b\u8bd5<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">perf lock<\/h2>\n\n\n\n<p>\u8ddf\u8e2a\u9501\u4e8b\u4ef6<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Flame Graph<\/h2>\n\n\n\n<p>\u6211\u4eec\u53ef\u4ee5\u5c06perf record\u8bb0\u5f55\u7684\u6570\u636e\u4ee5\u706b\u7130\u56fe\u7684\u5f62\u5f0f\u8f93\u51fa\uff0c\u66f4\u52a0\u7684\u76f4\u89c2\uff0c\u6709\u5229\u4e8e\u4eba\u7c7b\u7684\u9605\u8bfb<\/p>\n\n\n\n<p><a href=\"https:\/\/zhuanlan.zhihu.com\/p\/147875569\">https:\/\/zhuanlan.zhihu.com\/p\/147875569<\/a><\/p>\n\n\n\n<p>\u706b\u7130\u56fe\u5de5\u4f5c\u8c03\u4f18\u6027\u80fd\u505a\u62a5\u544a\u65f6\u7ecf\u5e38\u4f7f\u7528\uff0c\u5728\u6b64\u4e0d\u591a\u8d58\u8ff0\u4e86<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#f6f6f4;--cbp-line-number-width:calc(1 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#282A36\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#f6f6f4;display:none\" aria-label=\"\u590d\u5236\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>perf record -a -g -F 99 sleep 60\nperf script report flamegraph\ngoogle-chrome flamegraph.html<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M16.5 8.25V6a2.25 2.25 0 00-2.25-2.25H6A2.25 2.25 0 003.75 6v8.25A2.25 2.25 0 006 16.5h2.25m8.25-8.25H18a2.25 2.25 0 012.25 2.25V18A2.25 2.25 0 0118 20.25h-7.5A2.25 2.25 0 018.25 18v-1.5m8.25-8.25h-6a2.25 2.25 0 00-2.25 2.25v6\"><\/path><\/svg><\/span><pre class=\"shiki dracula-soft\" style=\"background-color: #282A36\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #62E884\">perf<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">record<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-a<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-g<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-F<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">99<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">sleep<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">60<\/span><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">perf<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">script<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">report<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">flamegraph<\/span><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">google-chrome<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">flamegraph.html<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<h1 class=\"wp-block-heading\">\u5b9e\u9a8c<\/h1>\n\n\n\n<h2 class=\"wp-block-heading\">\u73af\u5883\u642d\u5efa<\/h2>\n\n\n\n<p>\u7531\u4e8e\u6211\u5728\u5bbf\u820d\u4f7f\u7528\u7684\u662fWSL ubutnu\u7248\u672c\uff0c\u5176\u5bf9\u5fae\u8f6f\u9b54\u6539\u5185\u6838\u652f\u6301\u7684\u4e0d\u591f\u597d\uff0c\u6309\u7167\u7cfb\u7edf\u7684\u63d0\u793a\u4e0d\u80fd\u6210\u529f\u3002\u6b64\u95ee\u9898\u53ef\u4ee5\u901a\u8fc7\u624b\u52a8\u7f16\u8bd1\u3001\u6362\u53d1\u884c\u7248\u3001\u5b89\u88c5\u5176\u4ed6<a href=\"https:\/\/zhida.zhihu.com\/search?content_id=221573276&amp;content_type=Article&amp;match_order=1&amp;q=%E8%BD%AF%E4%BB%B6%E5%8C%85&amp;zhida_source=entity\">\u8f6f\u4ef6\u5305<\/a>\u7684\u65b9\u5f0f\u89e3\u51b3\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u624b\u52a8\u7f16\u8bd1perf<\/h3>\n\n\n\n<p>\u672c\u65b9\u6cd5\u53c2\u8003\u81ea\uff1a<a href=\"https:\/\/link.zhihu.com\/?target=https%3A\/\/gist.github.com\/abel0b\/b1881e41b9e1c4b16d84e5e083c38a13\">Install perf on WSL 2 \u00b7 GitHub<\/a><\/p>\n\n\n\n<p>\u4f9d\u6b21\u8fd0\u884c\u5982\u4e0b\u6307\u4ee4<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro cbp-has-line-numbers\" data-code-block-pro-font-family=\"Code-Pro-JetBrains-Mono\" style=\"font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;--cbp-line-number-color:#f6f6f4;--cbp-line-number-width:calc(1 * 0.6 * .875rem);line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#282A36\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" style=\"color:#f6f6f4;display:none\" aria-label=\"\u590d\u5236\" class=\"code-block-pro-copy-button\"><pre class=\"code-block-pro-copy-button-pre\" aria-hidden=\"true\"><textarea class=\"code-block-pro-copy-button-textarea\" tabindex=\"-1\" aria-hidden=\"true\" readonly>apt install flex bison\ngit clone https:\/\/github.com\/microsoft\/WSL2-Linux-Kernel --depth 1\ncd WSL2-Linux-Kernel\/tools\/perf\nmake -j8\nsudo cp perf \/usr\/local\/bin<\/textarea><\/pre><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M16.5 8.25V6a2.25 2.25 0 00-2.25-2.25H6A2.25 2.25 0 003.75 6v8.25A2.25 2.25 0 006 16.5h2.25m8.25-8.25H18a2.25 2.25 0 012.25 2.25V18A2.25 2.25 0 0118 20.25h-7.5A2.25 2.25 0 018.25 18v-1.5m8.25-8.25h-6a2.25 2.25 0 00-2.25 2.25v6\"><\/path><\/svg><\/span><pre class=\"shiki dracula-soft\" style=\"background-color: #282A36\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color: #62E884\">apt<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">install<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">flex<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">bison<\/span><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">git<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">clone<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">https:\/\/github.com\/microsoft\/WSL2-Linux-Kernel<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">--depth<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">1<\/span><\/span>\n<span class=\"line\"><span style=\"color: #97E1F1\">cd<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">WSL2-Linux-Kernel\/tools\/perf<\/span><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">make<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #BF9EEE\">-j8<\/span><\/span>\n<span class=\"line\"><span style=\"color: #62E884\">sudo<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">cp<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">perf<\/span><span style=\"color: #F6F6F4\"> <\/span><span style=\"color: #E7EE98\">\/usr\/local\/bin<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>\u88c5\u4e86\u4e00\u5806\u4f9d\u8d56~<\/p>\n<\/blockquote>\n\n\n\n<p>\u4f46\u662f\u67e5\u770bperf list\u53d1\u73b0\uff0c\u7531\u4e8eWSL2\u7684\u865a\u62df\u5316\u517c\u5bb9\u786c\u4ef6\u4e0d\u597d\uff0c\u4e0d\u652f\u6301\u90e8\u5206\u786c\u4ef6\u91c7\u6837\uff0c\u5982branch-miss\uff0c\u5148\u8fd9\u6837\u5427\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">perf script\u5b89\u88c5(for flame graph)<\/h3>\n\n\n\n<p><a href=\"https:\/\/askubuntu.com\/questions\/1397419\/how-can-i-get-pre-canned-scripts-for-perf-script\">https:\/\/askubuntu.com\/questions\/1397419\/how-can-i-get-pre-canned-scripts-for-perf-script<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Make tiny progress every day. \u2014\u2014yangnanbei \u53c2\u8003\u8d44\u6599\uff1a \u524d\u8a00 \u8fd8\u8bb0\u5f97 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":351,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[10,11],"tags":[68,67,49,66],"class_list":["post-329","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-linux","category-tools","tag-linux","tag-perf","tag-49","tag-66"],"_links":{"self":[{"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/posts\/329"}],"collection":[{"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/comments?post=329"}],"version-history":[{"count":6,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/posts\/329\/revisions"}],"predecessor-version":[{"id":342,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/posts\/329\/revisions\/342"}],"wp:featuredmedia":[{"embeddable":true,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/media\/351"}],"wp:attachment":[{"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/media?parent=329"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/categories?post=329"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/yangnanbei.top\/index.php\/wp-json\/wp\/v2\/tags?post=329"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}