Username: Password:

RHEL 4 性能优化
来源: ChinaUnix博客  作者: ChinaUnix博客   发布时间:2008-01-01 09:34:00

一、前言
本文档针对OOP8生产环境,具体优化策略需要根据实际情况进行调整;本文档将在以下几个方面来阐述怎样针对RedHat Enterprise Linux进行性能优化。
1)     Linux Proc文档系统,通过对Proc文档系统进行调整,达到性能优化的目的。
2)     Linux性能诊断工具,介绍怎样使用Linux自带的诊断工具进行性能诊断。
加粗斜体表示能够直接运行的命令。
下划线表示文档的内容。
二、/proc/sys/kernel/优化
1)     /proc/sys/kernel/ctrl-alt-del
该文档有一个二进制值,该值控制系统在接收到ctrl+alt+delete按键组合时怎样反应。这两个值分别是:
零(0)值,表示捕获ctrl+alt+delete,并将其送至 init 程式;这将允许系统能够安全地关闭和重启,就好象输入shutdown命令相同。
壹(1)值,表示不捕获ctrl+alt+delete,将执行非正常的关闭,就好象直接关闭电源相同。
缺省配置:0
建议配置:1,防止意外按下ctrl+alt+delete导致系统非正常重启。
2)     proc/sys/kernel/msgmax
该文档指定了从一个进程发送到另一个进程的消息的最大长度(bytes)。进程间的消息传递是在内核的内存中进行的,不会交换到磁盘上,所以假如增加该值,则将增加操作系统所使用的内存数量。
缺省配置:8192
3)     /proc/sys/kernel/msgmnb
该文档指定一个消息队列的最大长度(bytes)。
缺省配置:16384
4)     /proc/sys/kernel/msgmni
该文档指定消息队列标识的最大数目,即系统范围内最大多少个消息队列。
缺省配置:16
5)     /proc/sys/kernel/panic
该文档表示假如发生“内核严重错误(kernel panic)”,则内核在重新引导之前等待的时间(以秒为单位)。
零(0)秒,表示在发生内核严重错误时将禁止自动重新引导。
缺省配置:0
6)     proc/sys/kernel/shmall
该文档表示在任何给定时刻,系统上能够使用的共享内存的总量(bytes)。
缺省配置:2097152
7)     /proc/sys/kernel/shmmax
该文档表示内核所允许的最大共享内存段的大小(bytes)。
缺省配置:33554432
建议配置:物理内存 * 50%
实际可用最大共享内存段大小=shmmax * 98%,其中大约2%用于共享内存结构。
能够通过配置shmmax,然后执行ipcs -l来验证。
8)     /proc/sys/kernel/shmmni
该文档表示用于整个系统的共享内存段的最大数目(个)。
缺省配置:4096
9)     /proc/sys/kernel/threads-max
该文档表示内核所能使用的线程的最大数目。
缺省配置:2048
10) /proc/sys/kernel/sem
该文档用于控制内核信号量,信号量是System VIPC用于进程间通讯的方法。
建议配置:250 32000 100 128
第一列,表示每个信号集中的最大信号量数目。
第二列,表示系统范围内的最大信号量总数目。
第三列,表示每个信号发生时的最大系统操作数目。
第四列,表示系统范围内的最大信号集总数目。
所以,(第一列)*(第四列)=(第二列)
以上配置,能够通过执行ipcs -l来验证。
11) 待续。。。
三、/proc/sys/vm/优化
1)     /proc/sys/vm/block_dump
该文档表示是否打开Block Debug模式,用于记录任何的读写及Dirty Block写回动作。
缺省配置:0,禁用Block Debug模式
2)     /proc/sys/vm/dirty_background_ratio
该文档表示脏数据到达系统整体内存的百分比,此时触发pdflush进程把脏数据写回磁盘。
缺省配置:10
3)     /proc/sys/vm/dirty_expire_centisecs
该文档表示假如脏数据在内存中驻留时间超过该值,pdflush进程在下一次将把这些数据写回磁盘。
缺省配置:3000(1/100秒)
4)     /proc/sys/vm/dirty_ratio
该文档表示假如进程产生的脏数据到达系统整体内存的百分比,此时进程自行把脏数据写回磁盘。
缺省配置:40
5)     /proc/sys/vm/dirty_writeback_centisecs
该文档表示pdflush进程周期性间隔多久把脏数据写回磁盘。
缺省配置:500(1/100秒)
6)     /proc/sys/vm/vfs_cache_pressure
该文档表示内核回收用于directory和inode cache内存的倾向;缺省值100表示内核将根据pagecache和swapcache,把directory和inode cache保持在一个合理的百分比;降低该值低于100,将导致内核倾向于保留directory和inode cache;增加该值超过100,将导致内核倾向于回收directory和inode cache。
缺省配置:100
7)     /proc/sys/vm/min_free_kbytes
该文档表示强制Linux VM最低保留多少空闲内存(Kbytes)。
缺省配置:724(512M物理内存)
8)     /proc/sys/vm/nr_pdflush_threads
该文档表示当前正在运行的pdflush进程数量,在I/O负载高的情况下,内核会自动增加更多的pdflush进程。
缺省配置:2(只读)
9)     /proc/sys/vm/overcommit_memory
该文档指定了内核针对内存分配的策略,其值能够是0、1、2。
0, 表示内核将检查是否有足够的可用内存供给用进程使用;假如有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配任何的物理内存,而不管当前的内存状态怎样。
2, 表示内核允许分配超过任何物理内存和交换空间总和的内存(参照overcommit_ratio)。
缺省配置:0
10) /proc/sys/vm/overcommit_ratio
该文档表示,假如overcommit_memory=2,能够过载内存的百分比,通过以下公式来计算系统整体可用内存。
系统可分配内存=交换空间+物理内存*overcommit_ratio/100
缺省配置:50(%)
11) /proc/sys/vm/page-cluster
该文档表示在写一次到swap区的时候写入的页面数量,0表示1页,1表示2页,2表示4页。
缺省配置:3(2的3次方,8页)
12) /proc/sys/vm/swapiness
该文档表示系统进行交换行为的程度,数值(0-100)越高,越可能发生磁盘交换。
缺省配置:60
13) legacy_va_layout
该文档表示是否使用最新的32位共享内存mmap()系统调用,Linux支持的共享内存分配方式包括mmap(),Posix,System VIPC。
0, 使用最新32位mmap()系统调用。
1, 使用2.4内核提供的系统调用。
缺省配置:0
14) nr_hugepages
该文档表示系统保留的hugetlb页数。
15) hugetlb_shm_group
该文档表示允许使用hugetlb页创建System VIPC共享内存段的系统组ID。
16) 待续。。。
四、/proc/sys/fs/优化
1)     /proc/sys/fs/file-max
该文档指定了能够分配的文档句柄的最大数目。假如用户得到的错误消息声明由于打开
文档数已达到了最大值,从而他们不能打开更多文档,则可能需要增加该值。
缺省配置:4096
建议配置:65536
2)     /proc/sys/fs/file-nr
该文档和 file-max 相关,他有三个值:
已分配文档句柄的数目
已使用文档句柄的数目
文档句柄的最大数目
该文档是只读的,仅用于显示信息。
3)     待续。。。
五、/proc/sys/net/core/优化
  该目录下的配置文档主要用来控制内核和网络层之间的交互行为。
1) /proc/sys/net/core/message_burst
写新的警告消息所需的时间(以 1/10 秒为单位);在这个时间内系统接收到的其他警告消息会被丢弃。这用于防止某些企图用消息“淹没”系统的人所使用的拒绝服务(Denial of Service)攻击。
缺省配置:50(5秒)
2) /proc/sys/net/core/message_cost
该文档表示写每个警告消息相关的成本值。该值越大,越有可能忽略警告消息。
缺省配置:5
3) /proc/sys/net/core/netdev_max_backlog
该文档表示在每个网络接口接收数据包的速率比内核处理这些包的速率快时,允许送到队列的数据包的最大数目。
缺省配置:300
4) /proc/sys/net/core/optmem_max
该文档表示每个套接字所允许的最大缓冲区的大小。
缺省配置:10240
5) /proc/sys/net/core/rmem_default
该文档指定了接收套接字缓冲区大小的缺省值(以字节为单位)。
缺省配置:110592
6) /proc/sys/net/core/rmem_max
该文档指定了接收套接字缓冲区大小的最大值(以字节为单位)。
缺省配置:131071
7) /proc/sys/net/core/wmem_default
该文档指定了发送套接字缓冲区大小的缺省值(以字节为单位)。
缺省配置:110592
8) /proc/sys/net/core/wmem_max
该文档指定了发送套接字缓冲区大小的最大值(以字节为单位)。
缺省配置:131071
9) 待续。。。
六、/proc/sys/net/ipv4/优化
1)     /proc/sys/net/ipv4/ip_forward
该文档表示是否打开IP转发。
0,禁止
1,转发
缺省配置:0
2)     /proc/sys/net/ipv4/ip_default_ttl
该文档表示一个数据报的生存周期(Time To Live),即最多经过多少路由器。
缺省配置:64
增加该值会降低系统性能。
3)     /proc/sys/net/ipv4/ip_no_pmtu_disc
该文档表示在全局范围内关闭路径MTU探测功能。
缺省配置:0
4)     /proc/sys/net/ipv4/route/min_pmtu
该文档表示最小路径MTU的大小。
缺省配置:552
5)     /proc/sys/net/ipv4/route/mtu_expires
该文档表示PMTU信息缓存多长时间(秒)。
缺省配置:600(秒)
6)     /proc/sys/net/ipv4/route/min_adv_mss
该文档表示最小的MSS(Maximum Segment Size)大小,取决于第一跳的路由器MTU。
缺省配置:256(bytes)
6.1 IP Fragmentation
1)     /proc/sys/net/ipv4/ipfrag_low_thresh/proc/sys/net/ipv4/ipfrag_low_thresh
两个文档分别表示用于重组IP分段的内存分配最低值和最高值,一旦达到最高内存分配值,其他分段将被丢弃,直到达到最低内存分配值。
缺省配置:196608(ipfrag_low_thresh)
     262144(ipfrag_high_thresh)
2)     /proc/sys/net/ipv4/ipfrag_time
该文档表示一个IP分段在内存中保留多少秒。
缺省配置:30(秒)
6.2 INET Peer Storage
1)     /proc/sys/net/ipv4/inet_peer_threshold
INET对端存储器某个合适值,当超过该阀值条目将被丢弃。该阀值同样决定生存
时间连同废物收集通过的时间间隔。条目越多,存活期越低,GC 间隔越短。
缺省配置:65664
2)     /proc/sys/net/ipv4/inet_peer_minttl
条目的最低存活期。在重组端必须要有足够的碎片(fragment)存活期。这个最低
存活期必须确保缓冲池容积是否少于 inet_peer_threshold。该值以 jiffies为
单位测量。
缺省配置:120
3)     /proc/sys/net/ipv4/inet_peer_maxttl
条目的最大存活期。在此期限到达之后,假如缓冲池没有耗尽压力的话(例如:缓
冲池中的条目数目很少),不使用的条目将会超时。该值以 jiffies为单位测量。
缺省配置:600
4)     /proc/sys/net/ipv4/inet_peer_gc_mintime
废物收集(GC)通过的最短间隔。这个间隔会影响到缓冲池中内存的高压力。 该值
以 jiffies为单位测量。
缺省配置:10
2006-10-31 16:33 清水飘萍
5)     /proc/sys/net/ipv4/inet_peer_gc_maxtime
废物收集(GC)通过的最大间隔,这个间隔会影响到缓冲池中内存的低压力。 该值
以 jiffies为单位测量。
缺省配置:120
6.3 TCP Variables
1)     /proc/sys/net/ipv4/tcp_syn_retries
该文档表示本机向外发起TCP SYN连接超时重传的次数,不应该高于255;该值仅仅针对外出的连接,对于进来的连接由tcp_retries1控制。
缺省配置:5
2)     /proc/sys/net/ipv4/tcp_keepalive_probes
该文档表示丢弃TCP连接前,进行最大TCP保持连接侦测的次数。保持连接仅在
SO_KEEPALIVE套接字选项被打开时才被发送。
缺省配置:9(次)
3)     /proc/sys/net/ipv4/tcp_keepalive_time
该文档表示从不再传送数据到向连接上发送保持连接信号之间所需的秒数。
缺省配置:7200(2小时)
4)     /proc/sys/net/ipv4/tcp_keepalive_intvl
该文档表示发送TCP探测的频率,乘以tcp_keepalive_probes表示断开没有相应的TCP连接的时间。
缺省配置:75(秒)
5)     /proc/sys/net/ipv4/tcp_retries1
  该文档表示放弃回应一个TCP连接请求前进行重传的次数。
  
  缺省配置:3
6)     /proc/sys/net/ipv4/tcp_retries2
  该文档表示放弃在已建立通讯状态下的一个TCP数据包前进行重传的次数。
  
  缺省配置:15
7)     /proc/sys/net/ipv4/tcp_orphan_retries
在近端丢弃TCP连接之前,要进行多少次重试。默认值是 7 个,相当于 50秒?
16分钟,视 RTO 而定。假如您的系统是负载很大的web服务器,那么也许需
要降低该值,这类 sockets 可能会耗费大量的资源。另外参考
tcp_max_orphans。
8)     /proc/sys/net/ipv4/tcp_fin_timeout
对于本端断开的socket连接,TCP保持在FIN-WAIT-2状态的时间。对方可能
会断开连接或一直不结束连接或不可预料的进程死亡。默认值为 60 秒。过去在
2.2版本的内核中是 180 秒。您能够配置该值,但需要注意,假如您的机器为负
载很重的web服务器,您可能要冒内存被大量无效数据报填满的风险,
FIN-WAIT-2 sockets 的危险性低于 FIN-WAIT-1,因为他们最多只吃 1.5K
的内存,但是他们存在时间更长。另外参考 tcp_max_orphans。
缺省配置:60(秒)
9)     /proc/sys/net/ipv4/tcp_max_tw_buckets
系统在同时所处理的最大timewait sockets 数目。假如超过此数的话,
time-wait socket 会被立即砍除并且显示警告信息。之所以要设定这个限制,纯
粹为了抵御那些简单的 DoS 攻击,千万不要人为的降低这个限制,但是,假如
网络条件需要比默认值更多,则能够提高他(或许还要增加内存)。
缺省配置:180000
10) /proc/sys/net/ipv4/tcp_tw_recyle
打开快速 TIME-WAIT sockets 回收。除非得到技术专家的建议或需要,请不要随
意修改这个值。
缺省配置:0
11) /proc/sys/net/ipv4/tcp_tw_reuse
该文档表示是否允许重新应用处于TIME-WAIT状态的socket用于新的TCP连接。
缺省配置:0
12) /proc/sys/net/ipv4/tcp_max_orphans
系统所能处理不属于任何进程的TCP sockets最大数量。假如超过这个数量,那
么不属于任何进程的连接会被立即reset,并同时显示警告信息。之所以要设定这
个限制,纯粹为了抵御那些简单的 DoS 攻击,千万不要依赖这个或是人为的降
低这个限制。
缺省配置:8192
13) /proc/sys/net/ipv4/tcp_abort_on_overflow
当守护进程太忙而不能接受新的连接,就向对方发送reset消息,默认值是false。
这意味着当溢出的原因是因为一个偶然的猝发,那么连接将恢复状态。只有在您确
信守护进程真的不能完成连接请求时才打开该选项,该选项会影响客户的使用。
缺省配置:0
14) /proc/sys/net/ipv4/tcp_syncookies
该文档表示是否打开TCP同步标签(syncookie),内核必须打开了 CONFIG_SYN_COOKIES项进行编译。 同步标签(syncookie)能够防止一个套接字在有过多试图连接到达时引起过载。
缺省配置:0
15) /proc/sys/net/ipv4/tcp_stdurg
使用 TCP urg pointer 字段中的主机请求解释功能。大部份的主机都使用老旧的
BSD解释,因此假如您在 Linux 打开他,或会导致不能和他们正确沟通。
缺省配置:0
16) /proc/sys/net/ipv4/tcp_max_syn_backlog
对于那些依然还未获得客户端确认的连接请求,需要保存在队列中最大数目。对于
超过 128Mb 内存的系统,默认值是 1024,低于 128Mb 的则为 128。假如
服务器经常出现过载,能够尝试增加这个数字。警告!假如您将此值设为大于
1024,最好修改 include/net/tcp.h 里面的 TCP_SYNQ_HSIZE,以保持
TCP_SYNQ_HSIZE*16 0)或bytes-bytes/2^(-tcp_adv_win_scale)(如
果tcp_adv_win_scale 128Mb 32768-610000)则系统将忽略任何发送给自己
的ICMP ECHO请求或那些广播地址的请求。
缺省配置:1024
17) /proc/sys/net/ipv4/tcp_window_scaling
该文档表示配置tcp/ip会话的滑动窗口大小是否可变。参数值为布尔值,为1时表示可变,为0时表示不可变。tcp/ip通常使用的窗口最大可达到 65535 字节,对于高速网络,该值可能太小,这时候假如启用了该功能,能够使tcp/ip滑动窗口大小增大数个数量级,从而提高数据传输的能力。
缺省配置:1
18) /proc/sys/net/ipv4/tcp_sack
该文档表示是否启用有选择的应答(Selective Acknowledgment),这能够通过有选择地应答乱序接收到的报文来提高性能(这样能够让发送者只发送丢失的报文段);(对于广域网通信来说)这个选项应该启用,但是这会增加对 CPU 的占用。
缺省配置:1
19) /proc/sys/net/ipv4/tcp_timestamps
该文档表示是否启用以一种比超时重发更精确的方法(请参阅 RFC 1323)来启用对 RTT 的计算;为了实现更好的性能应该启用这个选项。
缺省配置:1
20) /proc/sys/net/ipv4/tcp_fack
该文档表示是否打开FACK拥塞避免和快速重传功能。
缺省配置:1
21) /proc/sys/net/ipv4/tcp_dsack
该文档表示是否允许TCP发送“两个完全相同”的SACK。
缺省配置:1
22) /proc/sys/net/ipv4/tcp_ecn
该文档表示是否打开TCP的直接拥塞通告功能。
缺省配置:0
23) /proc/sys/net/ipv4/tcp_reordering
该文档表示TCP流中重排序的数据报最大数量。
缺省配置:3
24) /proc/sys/net/ipv4/tcp_retrans_collapse
该文档表示对于某些有bug的打印机是否提供针对其bug的兼容性。
缺省配置:1
25) /proc/sys/net/ipv4/tcp_wmem
该文档包含3个整数值,分别是:min,default,max
Min:为TCP socket预留用于发送缓冲的内存最小值。每个TCP socket都能够使用他。
Default:为TCP socket预留用于发送缓冲的内存数量,默认情况下该值会影响其他协议使用的net.core.wmem中default的 值,一般要低于net.core.wmem中default的值。
Max:为TCP socket预留用于发送缓冲的内存最大值。该值不会影响net.core.wmem_max,今天选择参数SO_SNDBUF则不受该值影响。默认值为128K。
缺省配置:4096 16384 131072
26) /proc/sys/net/ipv4/tcp_rmem
该文档包含3个整数值,分别是:min,default,max
Min:为TCP socket预留用于接收缓冲的内存数量,即使在内存出现紧张情况下TCP socket都至少会有这么多数量的内存用于接收缓冲。
Default:为TCP socket预留用于接收缓冲的内存数量,默认情况下该值影响其他协议使用的 net.core.wmem中default的值。该值决定了在tcp_adv_win_scale、tcp_app_win和tcp_app_win的默认值情况下,TCP 窗口大小为65535。
Max:为TCP socket预留用于接收缓冲的内存最大值。该值不会影响 net.core.wmem中max的值,今天选择参数 SO_SNDBUF则不受该值影响。
缺省配置:4096 87380 174760
27) /proc/sys/net/ipv4/tcp_mem
该文档包含3个整数值,分别是:low,pressure,high
Low:当TCP使用了低于该值的内存页面数时,TCP不会考虑释放内存。
Pressure:当TCP使用了超过该值的内存页面数量时,TCP试图稳定其内存使用,进入pressure模式,当内存消耗低于low值时则退出pressure状态。
High:允许任何tcp sockets用于排队缓冲数据报的页面量。
一般情况下这些值是在系统启动时根据系统内存数量计算得到的。
缺省配置:24576 32768 49152
28) /proc/sys/net/ipv4/tcp_app_win
该文档表示保留max(window/2^tcp_app_win, mss)数量的窗口由于应用缓冲。当为0时表示无需缓冲。
缺省配置:31
29) /proc/sys/net/ipv4/tcp_adv_win_scale
该文档表示计算缓冲开销bytes/2^tcp_adv_win_scale(假如tcp_adv_win_scale >; 0)或bytes-bytes/2^(-tcp_adv_win_scale)(假如tcp_adv_win_scale


来自:
http://www.chinalinuxpub.com/read.php?wid=1644


本文来自ChinaUnix博客,假如查看原文请点:http://blog.chinaunix.net/u1/47765/showart_492239.html

喜欢本文,那就收藏到:

    Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网
相关评论  我也要评论
还没有关于此文章的相关评论!
  • 昵称: (为空则显示guest)
  • 评论分数: ★ ★ ★★★ ★★★★ ★★★★★
  • 评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
  • 导航
    赞助商
    文章类别
    订阅