• 1175阅读
  • 1回复

Linux核心优化方案,sysctl.conf的设置

楼层直达
GHc/Zc"iX  
$ /proc/sys/net/core/wmem_max最大socket写buffer,可参考的优化值:873200 3{7T4p.G  
$ /proc/sys/net/core/rmem_max最大socket读buffer,可参考的优化值:873200 WCq /c6 D  
$ /proc/sys/net/ipv4/tcp_wmemTCP写buffer,可参考的优化值:32768 436600 873200 N3A<:%s  
$ /proc/sys/net/ipv4/tcp_rmemTCP读buffer,可参考的优化值:32768 436600 873200 7L(e h7  
$ /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 n(ir[w#,]"  
$ /proc/sys/net/core/netdev_max_backlog进入包的最大设备队列.默认是1000,对重负载服务器而言,该值太低,可调整到16384. HTjkR*E  
$ /proc/sys/net/core/somaxconnlisten()的默认参数,挂起请求的最大数量.默认是128.对繁忙的服务器,增加该值有助于网络性能.可调整到8192. $K}DB N; 4  
$ /proc/sys/net/core/optmem_maxsocket buffer的最大初始化值,默认10K(10240).也可调整到20k(20480).但建议保留不变 'xK.U I  
$ /proc/sys/net/ipv4/tcp_max_syn_backlog进入SYN包的最大请求队列.默认1024.对重负载服务器,增加该值显然有好处.可调整到16384. Tbbz'b;{  
$ /proc/sys/net/ipv4/tcp_retries2TCP失败重传次数,默认值15,意味着重传15次才彻底放弃.可减少到5,以尽早释放内核 资源. &m^@9E)S/  
$ /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 = 9tcp_keepalive_intvl = 75 seconds意思是如果某个TCP连接在idle 2个小时后,内核才发起probe.如果probe 9次(每次75秒)不成功,内核才彻底放弃,认为该连接已失效.对服务器而言,显然上述值太大. 可调整到: :%r S =f  
/proc/sys/net/ipv4/tcp_keepalive_time 1800/proc/sys/net/ipv4/tcp_keepalive_probes 3/proc/sys/net/ipv4/tcp_keepalive_intvl 30 lHfe<j]  
$ proc/sys/net/ipv4/ip_local_port_range指定端口范围的一个配置,默认是32768 61000.可调整为1024 65535.---------- VDF)zA1V  
net.ipv4.tcp_syncookies = 1表示开启SYN Cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭。net.ipv4.tcp_tw_reuse = 1表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭。net.ipv4.tcp_tw_recycle = 1表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。net.ipv4.tcp_fin_timeout = 30表示如果套接字由本端要求关闭,这个参数决定了它保持在FIN-WAIT-2状态的时间。net.ipv4.tcp_keepalive_time= 1200表示当keepalive起用的时候,TCP发送keepalive消息的频度。缺省是2小时,改为20分钟。net.ipv4.ip_local_port_range = 1024 65535表示用于向外连接的端口范围。缺省情况下过窄:32768到61000,改为1024到65535。net.ipv4.tcp_max_syn_backlog = 16384表示SYN队列的长度,默认为1024,加大队列长度为8192,可以容纳更多等待连接的网络连接数。net.ipv4.tcp_max_tw_buckets = 180000表示系统同时保持TIME_WAIT套接字的最大数量,如果超过这个数字,TIME_WAIT套接字将立刻被清除并打印警告信息。默认为180000,可适当增大该值,但不建议减小。对于Apache、Nginx等服务器,以上几行参数的设置可以很好地减少TIME_WAIT套接字数量,但是对于Squid,效果却不大。此项参数可以控制TIME_WAIT套接字的最大数量,避免Squid服务器被大量的TIME_WAIT套接字拖死。
只看该作者 安逸沙发  发表于: 2019-09-30
一般设置: 0#Rj[J;kh  
1 #sudo vi /etc/sysctl.conf PMXnupt  
#在最后面编辑添加以下内容: 1`2lTkg  
#缺省socket写buffer,可参考的优化值:873200/1746400/3492800 r \=p.cw<  
net.core.wmem_default = 1746400 u$<FKp;I  
#最大socket写buffer,可参考的优化值:1746400/3492800/6985600  tEP^w  
net.core.wmem_max = 3492800 nV']^3b  
#缺省socket读buffer,可参考的优化值:873200/1746400/3492800 9h*$P:S;1v  
net.core.rmem_default = 1746400 E8NIH!dI  
#最大socket读buffer,可参考的优化值:1746400/3492800/6985600 #/1A:ig  
net.core.rmem_max = 3492800 _Q.3X[88C  
#进入包的最大设备队列.默认是1000,对重负载服务器而言,该值太低,可调整到16384/32768/65535 *bv Iqa  
net.core.netdev_max_backlog = 32768 w2$HP/90j  
#listen()的默认参数,挂起请求的最大数量.默认是128.对繁忙的服务器,增加该值有助于网络性能.可调整到8192/16384/32768 XTZWbhNF  
net.core.somaxconn = 16384 xn}'!S2-b  
#每个socket buffer的最大补助缓存大小,默认10K(10240),也可调整到20k(20480),但建议保留 pF"z)E|^  
net.core.optmem_max = 10240 )]qFI"B7  
#表示用于向外连接的端口范围.缺省情况下过窄:32768到61000,改为1024到65535 {bc<0  
net.ipv4.ip_local_port_range = 1024 65535 }T(|\ X  
#TCP写buffer,可参考的优化值:873200/1746400/3492800/6985600 tbOe,-U-@  
net.ipv4.tcp_wmem = 873200 1746400 3492800 xR1g  
#TCP读buffer,可参考的优化值:873200/1746400/3492800/6985600 GD< Afni  
net.ipv4.tcp_rmem = 873200 1746400 3492800 <T0-m?D_$  
#net.ipv4.tcp_mem[0]:低于此值,TCP没有内存压力. 2 ] 4R`[#  
#net.ipv4.tcp_mem[1]:在此值下,进入内存压力阶段. wlKL|N  
#net.ipv4.tcp_mem[2]:高于此值,TCP拒绝分配socket. 0s<o5`v  
#上述内存单位是页,而不是字节.可参考的优化值是:78643200/104857600/157286400 KE5f`h  
net.ipv4.tcp_mem = 78643200 104857600 157286400 _0vXujz  
#进入SYN包的最大请求队列.默认1024.对重负载服务器,增加该值显然有好处.可调整到16384/32768/65535 K"=v| a.  
net.ipv4.tcp_max_syn_backlog = 32768 b#XS.e/uf  
#TCP失败重传次数,默认值15,意味着重传15次才彻底放弃.可减少到5,以尽早释放内核资源 wbr"z7}  
net.ipv4.tcp_retries2 = 5 ;j/ur\37  
#以下3个参数与TCP KeepAlive有关.默认值是: 1W/= =+%I  
#tcp_keepalive_time = 7200 seconds (2 hours) #lct"8  
#tcp_keepalive_probes = 9 @cjhri|vH  
#tcp_keepalive_intvl = 75 seconds {b#c0>.8-  
#意思是如果某个TCP连接在idle 2个小时后,内核才发起probe.如果probe 9次(每次75秒)不成功,内核才彻底放弃,认为该连接已失效 (U7%Z<  
#对服务器而言,显然上述值太大.可调整到: 2%@j<yS  
net.ipv4.tcp_keepalive_time = 1800 s V77WF  
net.ipv4.tcp_keepalive_probes = 3 h hd n9n  
net.ipv4.tcp_keepalive_intvl = 30 D#k>.)g  
#表示开启SYN Cookies,当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭 #lB[]2]N  
net.ipv4.tcp_syncookies = 1 n%?g+@y,^  
#表示如果套接字由本端要求关闭,这个参数决定了它保持在FIN-WAIT-2状态的时间 ^lQ-w|7(  
net.ipv4.tcp_fin_timeout = 30  vb70~k  
#表示开启重用,允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭 M>v M@j  
#net.ipv4.tcp_tw_reuse = 1 h+Z|s  
#表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭 <T7y85  
#net.ipv4.tcp_tw_recycle = 1 #2WBYScW0  
#表示系统同时保持TIME_WAIT套接字的最大数量,如果超过这个数字,TIME_WAIT套接字将立刻被清除并打印警告信息 4XKg3l1  
#默认为180000,建议使用默认值,不建议调小 r^\^*FD |  
#net.ipv4.tcp_max_tw_buckets = 180000 \?C(fp R  
#其它的一些设置 l"cO@.T3  
net.ipv4.route.gc_timeout = 100 U2bb|6j  
net.ipv4.tcp_syn_retries = 2 |]I?^:I  
net.ipv4.tcp_synack_retries = 2 T}\U:@b  
保存退出: J%[K;WjrZJ  
2 #sudo /sbin/sysctl -p
快速回复

限100 字节
安逸网提示:如果您提交过一次失败了,可以用”恢复数据”来恢复帖子内容
 
认证码:
上一个 下一个