【问题标题】:Programmatically clear cache on mounted (SSD) disk in Linux在 Linux 中以编程方式清除挂载 (SSD) 磁盘上的缓存
【发布时间】:2013-08-24 01:50:12
【问题描述】:

我正在编写一个对磁盘性能感兴趣的应用程序。我之前使用的是较旧的机械磁盘,并使用this thread 中的技术在测量性能之前清除缓存:

// Clear cache for benchmarking                                               
sync();    
std::ofstream ofs("/proc/sys/vm/drop_caches");
ofs << "3" << std::endl;
ofs.close();

效果很好,并且给了我预期的结果 - 在清除缓存时测得的磁盘顺序读取速度约为 100 MB/s,在不使用缓存时要快很多倍。

前几天我安装了一个 SSD 磁盘,安装在 /media/ 下。重新启动计算机后,前几次测量结果符合预期(大约 300 MB/s),但当缓存启动时,它们显然要高得多。

我现在的问题是,自从将应用程序移至 SSD 后,我之前使用的代码行没有任何效果。该缓存是否以不同的方式表现,也许?我需要做些什么来清除它?现在唯一可行的方法是重新启动计算机。

【问题讨论】:

  • 致对此投反对票的人:请发表评论并指出原因,以便我修复它。
  • 这很奇怪,这些磁盘的行为应该相同,因为缓存位于操作系统的更高层...可能是别的东西,比如 SSD 上的读取缓存(注意:我不是甚至确定他们有一个......)?
  • @KarolyHorvath:您能详细说明一下读取缓存的想法吗?我是大多数这些事情的新手。
  • superuser.com/questions/309613/… ...只有在您阅读不多的情况下才有意义。如果您读取 100 兆字节,则存储内容的前几 mbs 应该没有太大区别。

标签: c++ linux caching hard-drive solid-state-drive


【解决方案1】:

您不会只说自己在做什么,以及是否还有其他东西也在以某种方式处理这些数据。您只能使用 drop_caches 从缓存中逐出未使用的数据 - 如果由于某种原因需要保留数据(例如,因为它是脏的并且需要写回),它将无法被逐出。来自kernel documentation for drop_caches

这是非破坏性操作,不会释放任何脏对象。 要增加此操作释放的对象数量,用户可以运行 sync 在写信给/proc/sys/vm/drop_caches 之前。这将最小化 系统上脏对象的数量并创建更多候选对象 掉了。

【讨论】:

    猜你喜欢
    • 2012-03-22
    • 1970-01-01
    • 1970-01-01
    • 2014-07-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-07-21
    • 1970-01-01
    相关资源
    最近更新 更多