我的服务器有8Gig的RAM和8Gigs配置为交换文件.我有内存密集型应用程序在运行这些应用程序的峰值负载在此期间我们发现交换使用量增加使用大约1 GIG的交换.
我有另一台服务器,带有4Gig的RAM和8 Gigs的交换以及运行在其上的类似内存密集型应用程序.但这里的交换使用率可以忽略不计.大约100 MB.
我想知道什么是确切的条件或基于哪个Linux将RAM中的进程内存交换到交换文件的粗略公式.
我知道它基于交换因素.它还有什么基础?交换文件大小?任何指向Linux内核文档/源代码的指针都会很好.
在2.6.28后的拆分LRU中,Linux swappiness是一个乘数,用于任意修改计算的分数,确定在两个LRU中建立的压力.
因此,例如在没有剩余可用内存的系统上 – 您拥有的现有内存的值是根据列为“活动”的内存的速率和页面升级为活动的频率来测量的.落入非活动列表.
在活动和非活动之间具有许多促销/降级页面的LRU具有很多用途.
通常文件支持的存储更便宜且更安全,当你的内存耗尽并自动给出200的修饰符时(这使得文件支持的内存比交换支持的内存(其值为0)无法比它繁殖200倍分数.
swappiness做的是通过将您给出的swappiness数量(默认值为60)减去文件内存并将您提供的swappiness值作为乘数添加到anon内存来修改此值.因此,默认的swappiness使您的匿名内存比文件内存贵80倍(文件为200-60,匿名为0 60).因此,在已经耗尽其所有内存的典型Linux系统上,页面缓存必须比匿名内存更加活跃80倍,以便将匿名内存换出以支持页面缓存.
如果将swappiness设置为100,则将修改器设置为100,将文件内存设置为100(200 – 100)的修改器,使两个LRU均等加权.因此,在需要提供匿名内存的页面缓存的文件繁重的系统不如页面缓存那么活跃,然后将匿名内存交换到磁盘以为额外的页面缓存腾出空间.