为什么使用BPF工具分析性能?
admin
2023-02-21 16:40:05
0

性能工具之所以使用扩展的BPF,部分原因在于它的可编程性。BPF程序可以执行自定义等待时间计算和统计摘要。仅这些功能就可以构成一个有趣的工具,并且还有许多其他具有这些功能的跟踪工具。使BPF与众不同的是,它还高效且生产安全,并且内置于Linux内核中。使用BPF,您可以在生产环境中运行这些工具,而无需添加任何新的内核组件。

让我们看一些输出和一个图表,以了解性能工具如何使用BPF。该示例来自我发布的早期BPF工具bitehist,该工具以直方图的形式显示了磁盘I/O的大小:

为什么使用BPF工具分析性能?


关键的变化是直方图可以在内核上下文中生成,这大大减少了复制到用户空间的数据量。这种效率的提高是如此之大,以至于它可以允许工具在生产中运行,否则这些工具将太昂贵。详细地:

在BPF之前,生成此直方图摘要的完整步骤为:

1.     在内核中:为磁盘I / O事件启用检测。

2.     在内核中,对于每个事件:将一条记录写入perf缓冲区。如果使用跟踪点(首选),则记录包含有关磁盘I / O的元数据的几个字段。

3.     在用户空间中:定期将所有事件的缓冲区复制到用户空间。

4.     在用户空间中:遍历每个事件,为字节字段解析事件元数据。其他字段将被忽略。

5.     在用户空间中:生成字节字段的直方图摘要。

注意:这些是可用的最佳步骤,但它们并没有显示唯一的方法。您可以安装树外跟踪器(例如SystemTap),但是根据您的内核和发行版,这可能会很艰难。您也可以修改内核代码,或开发自定义kprobe模块,但是这两种方法都涉及挑战,并带来风险。我开发了自己的解决方法,称为“ hacktogram”,其中涉及为直方图的每一行创建多个带范围过滤器的perf(1)统计计数器[16]。那太差了。

步骤2到步骤4对于高I / O系统具有高性能开销。想象一下,每秒传输10,000个磁盘I / O跟踪记录到用户空间程序以进行分析和汇总。

使用BPF,bitesize程序的步骤为:

1.     在内核中:启用对磁盘I / O事件的检测,并附加一个由bitesize定义的自定义BPF程序。

2.     在内核中,对于每个事件:运行BPF程序。它仅获取字节字段,并将其保存到自定义BPF映射直方图中。

3.     在用户空间中:一次读取BPF地图直方图并打印出来。

此方法避免了将事件复制到用户空间并对其进行重新处理的开销。它还避免了复制未使用的元数据字段。复制到用户空间的唯一数据显示在上一个输出中:“ count”列,它是数字数组。

相关内容

热门资讯

【今日要闻】“天天爱泰州麻将.... 网上科普关于“天天爱泰州麻将有没有挂”话题很是火热,小编也是针对天天爱泰州麻将作*弊开挂的方法以及开...
我来教教您“新皇豪牛牛.怎么开... 网上科普关于“新皇豪牛牛有没有挂”话题很是火热,小编也是针对新皇豪牛牛作*弊开挂的方法以及开挂对应的...
【今日要闻】“德州之夜.开挂器... 有 亲,根据资深记者爆料德州之夜是可以开挂的,确实有挂(咨询软件无需打开...
特朗普提名特战副司令执掌南方司... 美国国防部长赫格塞思19日宣布,美国总统特朗普提名美军特种作战司令部副司令弗朗西斯·多诺万出任南方司...
玩家分享攻略“皇豪众娱牛牛.可... 有 亲,根据资深记者爆料皇豪众娱牛牛是可以开挂的,确实有挂(咨询软件无需...
【今日要闻】“乐酷炸金花.辅助... 有 亲,根据资深记者爆料乐酷炸金花是可以开挂的,确实有挂(咨询软件无需打...
【第一财经】“中至万年麻将.有... 家人们!今天小编来为大家解答中至万年麻将透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里...
玩家分享攻略“麻友圈2挪来挪去... 网上科普关于“麻友圈2挪来挪去有没有挂”话题很是火热,小编也是针对麻友圈2挪来挪去作*弊开挂的方法以...
SpaceX罕见披露:一卫星疑... 转自:环球时报 据路透社19日报道,美国太空探索技术公司(SpaceX)表示,其旗下“星链”(Sta...
【今日要闻】“新三哥玩.可以开... 网上科普关于“新三哥玩有没有挂”话题很是火热,小编也是针对新三哥玩作*弊开挂的方法以及开挂对应的知识...