Linux   发布时间:2022-04-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了linux – 如何强制内核在NFS上缓存更多文件大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

我有一个专用的Web服务器,提供静态文件víaNFs.服务器有32GB的RAM,但缓存的内存永远不会增长超过16GB. 我非常确定SO可以分配更多,因为全天,缓存的内存保持固定在16GB,但是当logrotate运行时,缓存的内存增长到30GB. 我一直在玩/ proc / slabinfo(nfs_direct_cache nfs_read_data nfs_inode_cachE)中的几个值但
我有一个专用的Web服务器,提供静态文件víaNFs.服务器有32GB的RAM,但缓存的内存永远不会增长超过16GB.

我非常确定SO可以分配更多,因为全天,缓存的内存保持固定在16GB,但是当logrotate运行时,缓存的内存增长到30GB.

我一直在玩/ proc / slabinfo(nfs_direct_cache nfs_read_data nfs_inode_cachE)中的几个值但没有成功.

任何关于此的提示链接都将非常感激.

提前致谢.

解决方法

如果您谈论页面缓存,这与您访问的文件,您访问过的文件中的数据量以及文件的活动程度有关.

在现代内核上缓存文件时,它会立即标记为非活动状态,直到再次使用它为止.这并不意味着它从缓存中被逐出,但在具有更高内存压力的系统(活动的匿名映射页面)上,它可以很快被丢弃.

缓存大小也由内存压力决定.这基本上是扫描缓存的次数与从“非活动”升级为“活动”的页数的一小部分,反之亦然.反对从磁盘访问此数据需要多少磁盘搜索.因此实际上,扫描和维护缓存需要的时间比从磁盘访问某些数据要多,不会增加页面缓存大小.

可能是你没有通过文件访问产生足够的内存压力来指示使用更多的页面缓存会有任何好处.这意味着每天访问的页面大约有16G,并且这种情况不会经常变化.

我想在logrotate中如果您刚刚读取的文件(导致30G)被取消链接,那么它使用的页面就不再需要了.这可以解释为什么页面缓存大小再次减少.

AFAIK这只与后2.6.28内核有关,它们改变了内存管理算法.

大佬总结

以上是大佬教程为你收集整理的linux – 如何强制内核在NFS上缓存更多文件全部内容,希望文章能够帮你解决linux – 如何强制内核在NFS上缓存更多文件所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。