加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

有没有办法在Linux中获得块设备的Cache Hit / Miss比率?

发布时间:2020-12-13 18:37:30 所属栏目:Linux 来源:网络整理
导读:是否有可能在 Linux中看到有多少来自用户空间的读写请求最终导致块设备的缓存命中和未命中? 解决方法 您可以开发自己的 SystemTap脚本.您需要考虑以下两个子系统: VFS:这表示缓冲区缓存之前的所有I / O请求(即绝对每个I / O请求);检查“vfs.read”,“vfs.
是否有可能在 Linux中看到有多少来自用户空间的读写请求最终导致块设备的缓存命中和未命中?

解决方法

您可以开发自己的 SystemTap脚本.您需要考虑以下两个子系统:

> VFS:这表示缓冲区缓存之前的所有I / O请求(即绝对每个I / O请求);检查“vfs.read”,“vfs.write”和“kernel.function(”vfs_ *“)”探针;您需要按照各自的主要次要编号筛选出要监视的块设备.
> Block:这表示在I / O调度程序之前发送到块设备的所有I / O请求(它也会合并I / O请求的重新排序);在这里我们知道缓冲区缓存错过了哪些请求;查看“ioblock.request”探测器.

SystemTap开发需要一些时间来学习.如果您是一名温和的开发人员并且熟悉Linux,那么您应该在3-4天内完成.是的,学习需要时间,但您对结果非常满意 – SystemTap让您有机会(安全地)将探针放在Linux内核的几乎任何位置.

请注意,您的内核必须支持加载和卸载内核模块.现在大多数库存内核都支持这一点.您还需要为内核安装调试符号.对于我的Ubuntu系统,这就像下载几百MB的.deb文件一样简单,Ubuntu内核开发团队为我编译了这个文件.例如,这在SystemtapOnUbuntu Wiki页面上进行了解释.

附:只有在没有其他解决方案的情况下才采用SystemTap方法,因为这是一个全新的框架,您必须学习,这需要花费时间/金钱,有时甚至是挫败感.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读