perf - perf.data 太大,事件太少
问题描述
使用以下方法记录了一些统计数据:
perf record -a -F 20 -o perf.data -e major-faults sleep 1800
并获得perf.data
〜1GiB样本:355,事件计数:7592:
# Total Lost Samples: 0
#
# Samples: 355 of event 'major-faults'
# Event count (approx.): 7592
为什么几个样本占用了很多空间?是否有工具可以查看 perf.data 以找出它实际包含的内容?
使用命令:
perf report -i perf.data -D
我在 perf.data 中发现了这些事件:(剪切每个事件的十六进制转储)
0 0 0x63a0 [0x30]: PERF_RECORD_COMM: gmain:1000/1010
0x63d0 [0x38]: event: 7
0 0 0x63d0 [0x38]: PERF_RECORD_FORK(1004:1004):(1:1)
0x6408 [0x30]: event: 3
0 0 0x6408 [0x30]: PERF_RECORD_COMM: cron:1004/1004
0x6438 [0x70]: event: 10
0 0 0x6438 [0x70]: PERF_RECORD_MMAP2 1004/1004: [0x5586d93d0000(0xb000) @ 0 fd:01 3285696 93896821003936]: r-xp /usr/sbin/cron
但我没有要求 perf 用-e
选择器记录这些事件。如何避免记录这个?
解决方案
正如@osgx 已经提到的,查看perf.data
文件内部的工具是perf script
. 以十六进制格式perf script -D
从文件中转储原始事件。perf.data
该perf.data
文件包含性能监控单元生成的所有事件,以及一些元数据。磁盘perf.data
文件通常以perf_header
以下形式的结构开头 -
struct perf_header {
char magic[8]; /* PERFILE2 */
uint64_t size; /* size of the header */
uint64_t attr_size; /* size of an attribute in attrs */
struct perf_file_section attrs;
struct perf_file_section data;
struct perf_file_section event_types;
uint64_t flags;
uint64_t flags1[3];
};
该perf.data
文件的大部分内容包括 perf 事件,其中可以包括此处提到的任何事件类型,其中包含有关每个事件的元数据,例如 32 位进程 ID 和线程 ID、指令指针、有关正在使用的 CPU 的信息等。此元数据的存储取决于传递的各种标志,例如PERF_SAMPLE_PID
等PERF_SAMPLE_TID
。查看perf_event_open
手册页。您可以禁用记录某些元数据并减小写入文件的每个事件数据的大小。
,等是内核记录的边带事件PERF_RECORD_COMM
,有助于进一步的后处理和详细分析。它们在内核源代码中默认启用,可以在此处查看。PERF_RECORD_FORK
PERF_RECORD_MMAP
struct perf_event_attr {
........
mmap : 1, /* include mmap data */
comm : 1, /* include comm data */
freq : 1, /* use freq, not period */
inherit_stat : 1, /* per task counts */
enable_on_exec : 1, /* next exec enables */
task : 1, /* trace fork/exit */
在这些字段中设置 1 意味着它们默认启用,并且要禁用这些事件的日志记录,您必须在源代码中将它们设置为 0 并仅重新编译 kernel 的用户空间 perf 模块。如果设置为 0,这些事件将不会被记录,如此处所示。
没有带有 的命令行开关或选项perf record
可以禁用这些事件。
推荐阅读
- perl - 如何重新定位 PDF 的页面元素并写入新的 PDF?
- java - 如何将定时器添加到连接四?爪哇
- javascript - Nativescript 应用程序不会在 WebView 上打开文件选择器
- android - 如何在华为上显示应用图标徽章编号
- amazon-web-services - Docker 的 AWS CLI V2 问题
- amazon-web-services - AWS ElasticLoadBalancer 证书与域名不匹配
- typescript - 如何推断函数返回类型和参数名称和类型?
- java - 为什么 Java 的方法参数中没有动态绑定?
- javascript - 创建带有小胡子的动态下拉列表
- swiftui - 如何在 SwiftUI TabView 中保持滚动位置