linux下proc里关于磁盘性能的参数

我 们在磁盘写操作持续繁忙的服务器上曾经碰到一个特殊的性能问题。每隔 30 秒,服务器就会遇到磁盘写活动高峰,导致请求处理延迟非常大(超过3秒)。后来上网查了一下资料,通过调整内核参数,将写活动的高峰分布成频繁的多次写, 每次写入的数据比较少。这样可以把尖峰的写操作削平成多次写操作。以这种方式执行的效率比较低,因为内核不太有机会组合写操作。但对于繁忙的服务器,写操 作将更一致地进行,并将极大地改进交互式性能。

  下面是相关参数的调整:

一、2.6内核下

1、/proc/sys/vm/dirty_ratio  

这个参数控制文件系统的文件系统写缓冲区的大小,单位是百分比,表示系统内存的百分比,表示当写缓冲使用到系统内存多少的时候,开始向磁盘写出数据。增大 之会使用更多系统内存用于磁盘写缓冲,也可以极大提高系统的写性能。但是,当你需要持续、恒定的写入场合时,应该降低其数值,:

  echo '1' > /proc/sys/vm/dirty_ratio 

 

2、/proc/sys/vm/dirty_background_ratio  

这个参数控制文件系统的pdflush进程,在何时刷新磁盘。单位是百分比,表示系统内存的百分比,意思是当写缓冲使用到系统内存多少的时 候,pdflush开始向磁盘写出数据。增大之会使用更多系统内存用于磁盘写缓冲,也可以极大提高系统的写性能。但是,当你需要持续、恒定的写入场合时, 应该降低其数值,:

  echo '1' > /proc/sys/vm/dirty_background_ratio

3、/proc/sys/vm/dirty_writeback_centisecs  

这个参数控制内核的脏数据刷新进程pdflush的运行间隔。单位是 1/100 秒。缺省数值是500,也就是 5 秒。如果你的系统是持续地写入动作,那么实际上还是降低这个数值比较好,这样可以把尖峰的写操作削平成多次写操作。设置方法如下:

  echo "100" > /proc/sys/vm/dirty_writeback_centisecs  如果你的系统是短期地尖峰式的写操作,并且写入数据不大(几十M/次)且内存有比较多富裕,那么应该增大此数值:

  echo "1000" > /proc/sys/vm/dirty_writeback_centisecs

4、/proc/sys/vm/dirty_expire_centisecs  

这个参数声明Linux内核写缓冲区里面的数据多“旧”了之后,pdflush进程就开始考虑写到磁盘中去。单位是 1/100秒。缺省是 30000,也就是 30 秒的数据就算旧了,将会刷新磁盘。对于特别重载的写操作来说,这个值适当缩小也是好的,但也不能缩小太多,因为缩小太多也会导致IO提高太快。

  echo "100" > /proc/sys/vm/dirty_expire_centisecs  

当然,如果你的系统内存比较大,并且写入模式是间歇式的,并且每次写入的数据不大(比如几十M),那么这个值还是大些的好。

  

5、/proc/sys/vm/vfs_cache_pressure

   该文件表示内核回收用于directory和inode cache内存的倾向;缺省值100表示内核将根据pagecache和swapcache,把directory和inode cache保持在一个合理的百分比;降低该值低于100,将导致内核倾向于保留directory和inode cache;增加该值超过100,将导致内核倾向于回收directory和inode cache

  缺省设置:100   

6、/proc/sys/vm/min_free_kbytes

  该文件表示强制Linux VM最低保留多少空闲内存(Kbytes)。  缺省设置:724(512M物理内存)  

7、/proc/sys/vm/nr_pdflush_threads

该文件表示当前正在运行的pdflush进程数量,在I/O负载高的情况下,内核会自动增加更多的pdflush进程。  

缺省设置:2(只读)  

8、/proc/sys/vm/overcommit_memory

该文件指定了内核针对内存分配的策略,其值可以是0、1、2。

  0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。

  1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。

  2, 表示内核允许分配超过所有物理内存和交换空间总和的内存(参照overcommit_ratio)。  

缺省设置:0   

9、/proc/sys/vm/overcommit_ratio

  该文件表示,如果overcommit_memory=2,可以过载内存的百分比,通过以下公式来计算系统整体可用内存。

  系统可分配内存=交换空间+物理内存*overcommit_ratio/100   缺省设置:50(%)  

10、/proc/sys/vm/page-cluster

  该文件表示在写一次到swap区的时候写入的页面数量,0表示1页,1表示2页,2表示4页。  缺省设置:3(2的3次方,8页) 

11、/proc/sys/vm/swapiness

  该文件表示系统进行交换行为的程度,数值(0-100)越高,越可能发生磁盘交换。

二、2.4内核下  

通过修改文件/proc/sys/vm/bdflush实现。文件中的九个参数含义如下:

  nfract:dirty缓冲在缓冲区中的最大百分比。超过这个值将bdflush进程刷新硬盘。当可用内存比较少的情况下,将引发大量的磁盘I/O。为了均衡磁盘I/O,可以保持一个比较低的值。

  Ndirty:bdflush进程一次写入磁盘的最大dirty缓冲块数量。这个值比较大将导致I/O急剧增加,如果这个比较小,bdflush进程执行不够从而可能导致内存的瓶颈。

  Dummy2 :未使用

  Dummy3:未使用

  Interval:kupdated工作和刷新的最小频率,默认值是5秒。最小值是0秒最大值是600秒。

  Age_buffer:缓冲数据写到磁盘之前操作系统等待的最大时间。默认值是30秒,最小值是1秒最大值是6000秒。

  Nfract_sync:dirty缓存激活bdflush进程同步的百分比。默认值是60%。

  Nfract_stop:dirty缓存停止bdflush进程的百分比。默认值是20%。

  Dummy5:未使用

  比如在一个写操作频繁的数据库服务器上设置:

  10 500 0 0 50 30 10 0 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux系统中,/proc/meminfo文件包含了有关系统内存状态的信息。以下是一些常见参数及其含义: 1. MemTotal:系统的总内存大小。 2. MemFree:系统可用的空闲内存大小。 3. Buffers:用于块设备(如硬盘)的缓存大小。 4. Cached:用于文件系统的缓存大小。 5. SwapCached:从交换分区中缓存的内存大小。 6. SwapTotal:交换分区的总大小。 7. SwapFree:交换分区可用的空闲大小。 8. Dirty:等待被写回到磁盘的脏页大小。 9. Writeback:正在被写回到磁盘的脏页大小。 10. AnonPages:未映射的匿名内存大小。 11. Mapped:文件映射的大小。 12. Shmem:共享内存的大小。 13. Slab:内核数据结构缓存的大小。 14. SReclaimable:可回收的Slab大小。 15. SUnreclaim:不可回收的Slab大小。 16. KernelStack:内核栈的大小。 17. PageTables:页面表的大小。 18. NFS_Unstable:不稳定的NFS文件系统页大小。 19. Bounce:从设备中反弹回来的页面大小。 20. CommitLimit:系统可以分配的内存上限。 21. Committed_AS:系统当前已经分配的内存大小。 22. VmallocTotal:虚拟内存总大小。 23. VmallocUsed:已使用的虚拟内存大小。 24. VmallocChunk:最大的连续虚拟内存块大小。 25. HardwareCorrupted:硬件故障引起的页面数量。 26. AnonHugePages:大页匿名内存大小。 27. HugePages_Total:系统支持的大页数量。 28. HugePages_Free:系统剩余的大页数量。 29. Hugepagesize:大页大小。 这些参数可以帮助我们了解系统内存的使用情况,以便进行性能调优和资源管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值