使用 DAMON 入门指南
本文档简要描述了如何使用 DAMON,并演示了其默认用户空间工具。请注意,出于简洁起见,本文档仅描述了其部分功能。更多细节,请参考工具的使用文档。
先决条件
内核
首先,您应确保系统正在运行具有 CONFIG_DAMON_*=y 构建的内核。
用户空间工具
在演示中,我们将使用 DAMON 的默认用户空间工具,称为 DAMON Operator(DAMO)。它可在 https://github.com/awslabs/damo 获取。下面的示例假设 damo 已在您的 $PATH 中。尽管这不是强制的。
由于 DAMO 使用 DAMON 的 sysfs 接口(详细使用方法请参考详细用法),您应确保 sysfs 已挂载。
记录数据访问模式
以下命令记录程序的内存访问模式,并将监控结果保存到文件中。
$ git clone https://github.com/sjp38/masim
$ cd masim; make; ./masim ./configs/zigzag.cfg &
$ sudo damo record -o damon.data $(pidof masim)
命令的前两行下载一个人工内存访问生成器程序,并在后台运行它。生成器将重复访问两个大小为 100 MiB 的内存区域。您可以用您的真实工作负载替换它。最后一行要求 damo 将访问模式记录在 damon.data 文件中。
可视化记录的模式
您可以以热图的形式可视化模式,显示哪个内存区域(x 轴)在何时(y 轴)以及多频繁(数字)被访问。
$ sudo damo report heats --heatmap stdout
22222222222222222222222222222222222222211111111111111111111111111111111111111100
44444444444444444444444444444444444444434444444444444444444444444444444444443200
44444444444444444444444444444444444444433444444444444444444444444444444444444200
33333333333333333333333333333333333333344555555555555555555555555555555555555200
33333333333333333333333333333333333344444444444444444444444444444444444444444200
22222222222222222222222222222222222223355555555555555555555555555555555555555200
00000000000000000000000000000000000000288888888888888888888888888888888888888400
00000000000000000000000000000000000000288888888888888888888888888888888888888400
33333333333333333333333333333333333333355555555555555555555555555555555555555200
88888888888888888888888888888888888888600000000000000000000000000000000000000000
88888888888888888888888888888888888888600000000000000000000000000000000000000000
33333333333333333333333333333333333333444444444444444444444444444444444444443200
00000000000000000000000000000000000000288888888888888888888888888888888888888400
[...]
# access_frequency: 0 1 2 3 4 5 6 7 8 9
# x-axis: space (139728247021568-139728453431248: 196.848 MiB)
# y-axis: time (15256597248362-15326899978162: 1 m 10.303 s)
# resolution: 80x40 (2.461 MiB and 1.758 s for each character)
您还可以以按大小排序的方式可视化工作集大小的分布。
$ sudo damo report wss --range 0 101 10
# <percentile> <wss>
# target_id 18446632103789443072
# avr: 107.708 MiB
0 0 B | |
10 95.328 MiB |**************************** |
20 95.332 MiB |**************************** |
30 95.340 MiB |**************************** |
40 95.387 MiB |**************************** |
50 95.387 MiB |**************************** |
60 95.398 MiB |**************************** |
70 95.398 MiB |**************************** |
80 95.504 MiB |**************************** |
90 190.703 MiB |********************************************************* |
100 196.875 MiB |***********************************************************|
使用上述命令的 --sortby 选项,您可以显示工作集大小的时间变化情况。
$ sudo damo report wss --range 0 101 10 --sortby time
# <percentile> <wss>
# target_id 18446632103789443072
# avr: 107.708 MiB
0 3.051 MiB | |
10 190.703 MiB |***********************************************************|
20 95.336 MiB |***************************** |
30 95.328 MiB |***************************** |
40 95.387 MiB |***************************** |
50 95.332 MiB |***************************** |
60 95.320 MiB |***************************** |
70 95.398 MiB |***************************** |
80 95.398 MiB |***************************** |
90 95.340 MiB |***************************** |
100 95.398 MiB |***************************** |
数据访问模式感知的内存管理
以下命令将使您的工作负载中未访问时间超过 60 秒的大小 >=4K 的每个内存区域被交换出去。
$ sudo damo schemes --damos_access_rate 0 0 --damos_sz_region 4K max \
--damos_age 60s max --damos_action pageout \
<您的工作负载的 pid>
以上是 DAMON 的简要使用说明,希望对您有所帮助。
标签:95.398,入门,--,MiB,damo,DAMON,ChatGPT,内存 From: https://www.cnblogs.com/pengdonglin137/p/17898364.html