2011年12月28日 星期三

Linux Network Tuning Linux網路環境性能優化調整


如下網路配置參數調整,主要是針對請求壓力大的Linux (2.6 kernel)伺服器而言.
如果伺服器壓力不大,那麼維持默認即可.

下述內容取材於"Performance Tuning For Linux Server"一書.

$ /proc/sys/net/core/wmem_max
最大socketbuffer,可參考的優化值:873200

$ /proc/sys/net/core/rmem_max
最大socketbuffer,可參考的優化值:873200

$ /proc/sys/net/ipv4/tcp_wmem
TCPbuffer,可參考的優化值: 8192  436600  873200

$ /proc/sys/net/ipv4/tcp_rmem
TCPbuffer,可參考的優化值: 32768  436600  873200

$ /proc/sys/net/ipv4/tcp_mem
同樣有3個值,意思是:
net.ipv4.tcp_mem[0]:低於此值,TCP沒有記憶體壓力.
net.ipv4.tcp_mem[1]:在此值下,進入記憶體壓力階段.
net.ipv4.tcp_mem[2]:高於此值,TCP拒絕分配socket.
上述記憶體單位是頁,而不是位元組.
可參考的優化值是:786432  1048576 1572864

$ /proc/sys/net/core/netdev_max_backlog
進入包的最大設備佇列.預設是300,對重負載伺服器而言,該值太低,可調整到1000.

$ /proc/sys/net/core/somaxconn
listen()的默認參數,掛起請求的最大數量.默認是128.對繁忙的伺服器,增加該值有助於網路性能.
可調整到256.

$ /proc/sys/net/core/optmem_max
socket buffer的最大初始化值,默認10K.

$ /proc/sys/net/ipv4/tcp_max_syn_backlog
進入SYN包的最大請求佇列.默認1024.對重負載伺服器,增加該值顯然有好處.
可調整到2048.

$ /proc/sys/net/ipv4/tcp_retries2
TCP失敗重傳次數,預設值15,意味著重傳15次才徹底放棄.可減少到5,以儘早釋放內核資源.

$ /proc/sys/net/ipv4/tcp_keepalive_time
$ /proc/sys/net/ipv4/tcp_keepalive_intvl
$ /proc/sys/net/ipv4/tcp_keepalive_probes
3個參數與TCP KeepAlive有關.預設值是:
tcp_keepalive_time = 7200 seconds (2 hours)
tcp_keepalive_probes = 9
tcp_keepalive_intvl = 75 seconds
意思是如果某個TCP連接在idle 2個小時後,內核才發起probe.
如果probe 9(每次75)不成功,內核才徹底放棄,認為該連接已失效.
對伺服器而言,顯然上述值太大. 可調整到:
/proc/sys/net/ipv4/tcp_keepalive_time  1800
/proc/sys/net/ipv4/tcp_keepalive_intvl  30
/proc/sys/net/ipv4/tcp_keepalive_probes  3

$ proc/sys/net/ipv4/ip_local_port_range
指定埠範圍的一個配置,預設是32768   61000,已夠大

沒有留言: