`

转:linux 文件系统IO性能优化

阅读更多
对于LINUX SA来说,服务器性能是需要我们特别关注的,包括CPU、IO、内存等等系统的优化变得至关重要,这里转载一篇非常不错的关于IO优化的文章,供大家参考和学习:

一、关于页面缓存的信息,可以用

cat /proc/meminfo 
看到。其中的Cached 指用于pagecache的内存大小(diskcache-SwapCache)。随着写入缓存页,Dirty 的值会增加。
一旦开始把缓存页写入硬盘,Writeback的值会增加直到写入结束。 Linux 用pdflush进程把数据从缓存页写入硬盘,查看有多少个pdflush进程
cat /proc/sys/vm/nr_pdflush_threadspdflush的行为受/proc/sys/vm中的参数的控制
/proc/sys/vm/dirty_writeback_centisecs (default 500): 
1/100秒, 多长时间唤醒pdflush将缓存页数据写入硬盘。默认5秒唤醒2个(更多个)线程。
如果wrteback的时间长于dirty_writeback_centisecs的时间,可能会出问题。

 

pdflush的第一件事是读取
/proc/sys/vm/dirty_expire_centiseconds (default 3000)
1/100秒。缓存页里数据的过期时间(旧数据),在下一个周期内被写入硬盘。默认30秒是一个很长的时间。

第二件事是判断内存是否到了要写入硬盘的限额,由参数决定:
/proc/sys/vm/dirty_background_ratio (default 10)
百分值,保留过期页缓存(脏页缓存)的最大值。是以MmeFree+Cached-Mapped的值为基准的

pdflush写入硬盘看两个参数:
1 数据在页缓存中是否超出30秒,如果是,标记为脏页缓存;
2 脏页缓存是否达到工作内存的10%;

以下参数也会影响到pdflush
/proc/sys/vm/dirty_ratio (default 40)
总内存的最大百分比,系统所能拥有的最大脏页缓存的总量。超过这个值,开启pdflush写入硬盘。如果cache增长快于pdflush,那么整个系统在40%的时候遇到I/O瓶颈,所有的I/O都要等待cache被pdflush进硬盘后才能重新开始。

对于有高度写入操作的系统
dirty_background_ratio: 主要调整参数。如果需要把缓存持续的而不是一下子大量的写入硬盘,降低这个值。
dirty_ratio:        第二调整参数。

Swapping参数
/proc/sys/vm/swappiness
默认,linux倾向于从物理内存映射到硬盘缓存,保持硬盘缓存尽可能大。未用的页缓存会被放进swap区。
数值为0,将会避免使用swapping
100,将会尽量使用swapping
少用swapping会增加程序的响应速度;多用swapping将会提高系统的可用性。

如果有大量的写操作,为避免I/O的长时间等待,可以设置:
$ echo 5 > /proc/sys/vm/dirty_background_ratio
$ echo 10 > /proc/sys/vm/dirty_ratio

文件系统数据缓冲需要频繁的内存分配。加大保留内存的值能提升系统速度和稳定。小于8G的内存,保留内存为64M,大于8G的设置为256M
$ echo 65536 > /proc/sys/vm/min_free_kbytes

I/O 调度器
cat /sys/block/[disk]/queue/scheduler

4中调度算法
noop anticipatory deadline [cfq] 
deadline :    deadline 算法保证对既定的IO请求以最小的延迟时间。
anticipatory:    有个IO发生后,如果又有进程请求IO,则产生一个默认6ms猜测时间,猜测下一个进程请求IO是干什么。这对于随机读取会造成较大的延时。
对数据库应用很糟糕,而对于Web Server等则会表现不错。
cfq:        对每个进程维护一个IO队列,各个进程发来的IO请求会被cfq以轮循方式处理,对每一个IO请求都是公平。适合离散读的应用。
noop:        对所有IO请求都用FIFO队列形式处理。默认IO不会存在性能问题。

改变调度器
$ echo deadline > /sys/block/sdX/queue/scheduler
对于数据库服务器,deadline算法是推荐的。

提高调度器请求队列的
$ echo 4096 > /sys/block/sdX/queue/nr_requests

有大量的读请求,默认的请求队列应付不过来,可以提高这个值。缺点是要牺牲一定的内存。
为了增加连续读取的吞吐量,可以增加预读数据量。预读的实际值是自适应的,所以使用一个较高的值,不会降低小型随机存取的性能。
$ echo 4096 > /sys/block/sdX/queue/read_ahead_kb
如果LINUX判断一个进程在顺序读取文件,那么它会提前读取进程所需文件的数据,放在缓存中。

服务器遇到磁盘写活动高峰,导致请求处理延迟非常大(超过3秒)。通过调整内核参数,将写活动的高峰分布成频繁的多次写,每次写入的数据比较少。这样可以把尖峰的写操作削平成多次写操作。以这种方式执行的效率比较低,因为内核不太有机会组合写操作。但对于繁忙的服务器,写操作将更一致地进行,并将极大地改进交互式性能。

<strong>/proc/sys/vm/dirty_ratio </strong>

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

<strong>/proc/sys/vm/dirty_background_ratio</strong>

控制文件系统的pdflush进程,在何时刷新磁盘。单位是百分比,表示系统内存的百分比,pdflush用于将内存中的内容和文件系统进行同步,比如说,当一个文件在内存中进行修改,pdflush负责将它写回硬盘.每当内存中的垃圾页(dirty page)超过10%的时候,pdflush就会将这些页面备份回硬盘.增大之会使用更多系统内存用于磁盘写缓冲,也可以极大提高系统的写性能。但是,当你需要持续、恒定的写入场合时,应该降低其数值:

<strong>/proc/sys/vm/dirty_writeback_centisecs</strong>

控制内核的脏数据刷新进程pdflush的运行间隔。单位是 1/100 秒。缺省数值是500,也就是 5 秒。如果你的系统是持续地写入动作,那么实际上还是降低这个数值比较好,这样可以把尖峰的写操作削平成多次写操作。
如果你的系统是短期地尖峰式的写操作,并且写入数据不大(几十M/次)且内存有比较多富裕,那么应该增大此数值。
该参数的设置应该小于dirty_expire_centisecs,但也不能太小,太小I/O太频繁,反而
使系统性能下降。具体可能需要在生产环境上测试。据说1:6 (dirty_expire_centisecs  : dirty_writeback_centisecs )的比例比较好。

<strong>/proc/sys/vm/dirty_expire_centisecs</strong>

声明Linux内核写缓冲区里面的数据多“旧”了之后,pdflush进程就开始考虑写到磁盘中去。单位是 1/100秒。缺省是 30000,也就是 30 秒的数据就算旧了,将会刷新磁盘。对于特别重载的写操作来说,这个值适当缩小也是好的,但也不能缩小太多,因为缩小太多也会导致IO提高太快。
当然,如果你的系统内存比较大,并且写入模式是间歇式的,并且每次写入的数据不大(比如几十M),那么这个值还是大些的好。

<strong>/proc/sys/vm/vfs_cache_pressure</strong>

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

<strong>/proc/sys/vm/min_free_kbytes</strong>

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

<strong>/proc/sys/vm/nr_pdflush_threads</strong>

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

<strong>/proc/sys/vm/overcommit_memory</strong>

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

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

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

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

缺省设置:0

<strong>/proc/sys/vm/overcommit_ratio</strong>

如果overcommit_memory=2,可以过载内存的百分比,通过以下公式来计算系统整体可用内存。系统可分配内存=交换空间+物理内存*overcommit_ratio/100
缺省设置:50(%)

<strong>/proc/sys/vm/page-cluster</strong>

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

<strong>/proc/sys/vm/swapiness</strong>

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

更改:
/etc/sysctl.conf

<strong>vm.dirty_ratio = 40</strong>

sysctl -p

查看:

<strong>find /proc/sys/vm -name dirty* -print | while read name; do echo $name ;cat ${<strong>name</strong> </strong>
分享到:
评论

相关推荐

    Linux-IO性能优化基础工具和实践

    Linux-IO性能优化基础工具和实践: 基础篇-Linux IO stack overview 基础篇-read syscall IO stack 工具篇-iostat数据可靠吗 工具篇-blktrace原理和应用 工具篇-debugfs应用 Cache server机械盘IO性能瓶颈分析 实践...

    漫谈linux文件IO

    通过深入理解 Linux 文件 I/O 的各个层面及其工作原理,我们可以更有效地优化应用程序中的 I/O 操作,进而提升整个系统的性能。无论是选择合适的缓冲策略,还是利用特定的技术如 `mmap` 或 `O_DIRECT`,都需要根据...

    34 生产经验:Linux操作系统的存储系统软件层原理剖析以及IO调度优化原理.pdf

    3. 使用SSD等高速存储设备:固态硬盘(SSD)的访问速度远高于传统机械硬盘(HDD),通过替换或混合使用高速存储设备,能够显著提高数据库IO性能。 4. 使用RAID技术:通过冗余阵列独立磁盘(RAID)技术可以提高数据...

    Linux性能优化之IO子系统

    本文介绍了对LinuxIO子系统性能进行优化时需要考虑的因素,以及一些IO性能检测工具。本文的大部分内容来自IBMRedbook-LinuxPerformanceandTuningGuidelines文件系统是内核的功能,是一种工作在内核空间的软件,访问...

    行业-34 生产经验:Linux操作系统的存储系统软件层原理剖析以及IO调度优化原理.rar

    在IT行业中,Linux操作系统...理解Linux存储系统软件层的工作原理并掌握IO调度优化技巧,对于提升系统性能和稳定性至关重要。在实际生产环境中,根据不同的业务场景灵活应用这些知识,能够显著改善系统整体的运行效率。

    linux文件IO编程ppt

    本讲座主要围绕"Linux文件IO编程"展开,由知名的教育机构华清远见出品,质量可靠,内容深入浅出。 首先,我们来了解一下Linux文件系统的基本概念。在Linux中,一切皆为文件,包括硬件设备、网络接口等,都被抽象为...

    03linux内核IO性能优化及块BIO处理

    Linux内核中的IO性能优化和块BIO处理是操作系统核心中的关键部分,涉及到高效的数据读写操作。在Linux系统中,每个块设备都有一个与之关联的请求队列(request_queue),这是处理I/O请求的核心结构。在块设备初始化...

    Linux Cgroup 技术 与 智能手机系统 IO 优化

    Linux Cgroups(控制组)技术是Linux内核的一个功能,旨在限制、记录、隔离和优先级设定进程组对系统资源(如CPU、内存、磁盘IO和网络等)的使用。此技术自2006年由Google的工程师(主要是Paul Menage和Rohit Seth)...

    顺藤摸瓜之Linux文件系统

    ### 顺藤摸瓜之Linux文件系统 #### 引言 在深入了解Linux文件系统的运作机制前,我们需要先明确几个基础概念。文件系统是操作系统的重要组成部分,它负责管理和组织计算机存储设备上的文件。对于Linux这样的多用途...

    Linux系统性能优化经验.pdf

    Linux系统性能优化是一个涵盖多个层面的复杂任务,包括硬件配置、操作系统设置以及应用程序的优化。以下是对标题和描述中提到的知识点的详细说明: 1. **系统硬件资源优化**: - **CPU**:对于多核CPU,若发现业务...

    Linux性能优化_linux性能优化_linux_

    在IT领域,Linux系统的性能优化是一项至关重要的任务,尤其对于那些依赖高性能计算或者需要高效运行服务的项目。本文将深入探讨Linux性能优化的关键方面,帮助你理解如何通过一系列策略和工具提升系统的整体效能。 ...

    suse系统与susert系统IO性能评测研究.pdf

    目前,针对Linux内核中的文件系统、调度策略等方面的研究工作较多,但专门针对闪存设备特别是基于SUSE和SUSERT(假设这是一个特定的版本或配置)的IO性能分析与优化工作却相对较少。因此,本文旨在深入分析Linux内核...

    linux IO优化

    Linux I/O调度算法是系统性能优化的关键因素之一。理解每种算法的特点和适用场景,并根据实际需求选择合适的算法,可以在很大程度上改善系统的响应时间和吞吐量。通过本篇文章的介绍,我们不仅了解了Linux系统提供的...

    Linux IO数据通道我理解

    块IO层是Linux IO架构中的核心组成部分之一,它位于文件系统层和设备驱动层之间。该层的主要功能包括: 1. **缓存管理**:利用内存作为缓存,提高数据读写速度。 2. **请求合并**:通过合并相邻或相近的IO请求,...

    详解linux下使用IOMETER测试磁盘IO性能.doc

    "Linux 下使用 IOMETER 测试磁盘 IO 性能详解" Linux 作为一个开源的操作系统,具有...IOMETER 是一个非常实用的磁盘 IO 测试工具,在 Linux 下使用 IOMETER 可以轻松地测试磁盘 IO 性能,从而优化系统的整体性能。

    Linux IO数据通道我理解之分享

    为了更好地管理和优化IO操作,Linux内核设计了一套复杂的IO数据通道处理机制。这一机制主要由几个关键层次构成: 1. **用户空间与内核空间交互层**:用户空间的应用程序通过系统调用如`read()`、`write()`等与内核...

Global site tag (gtag.js) - Google Analytics