我目前正在做一个项目,我需要测试它的性能。因此,我正在开发一个C客户机,它可以重复地访问文件中的随机磁盘页面。该客户端面向Linux Debian OS (64位),并按如下方式运行:
一开始,它分配一个动态的内存结构,该结构保存它将访问的页面的信息。然后,在多次循环期间,它从文件中获取每个页面的数据。
为了监视底层的FileSystem性能,我想强制客户机用新页面替换内存内容,而不是通过缓存来提高性能。因此,我让它使用它的大部分RAM (它有512MB的主内存,我强制它使用大约300MB)。事实是,我不会监控性能下降。
有没有其他方法可以强制替换主内存中的内存页,这样我就可以监控客户端调用中的IO延迟?
发布于 2013-06-10 18:24:22
您可以通过执行以下操作(以root用户身份)刷新内存缓存:
sync
echo 3 > /proc/sys/vm/drop_cachesdrop_caches接受的各种values包括:
To free pagecache:
echo 1 > /proc/sys/vm/drop_caches
To free dentries and inodes:
echo 2 > /proc/sys/vm/drop_caches
To free pagecache, dentries and inodes:
echo 3 > /proc/sys/vm/drop_caches你需要3个才能放下所有的东西。
https://stackoverflow.com/questions/17021336
复制相似问题