Centos7 TCP断线系统检测时间配置及TCP服务器优化

 

配置客户端异常断线检测时间
代码中:((SocketSessionConfig)session.getConfig()).setKeepAlive(true);
系统设置如下
vi /etc/sysctl.conf

#jxm---------
net.ipv4.tcp_fin_timeout = 40
#10s
#当探测没有确认时,重新发送探测的频度。默认是75秒。 现在是3秒
net.ipv4.tcp_keepalive_intvl = 10

#在认定连接失效之前,发送多少个TCP的keepalive探测包。默认值是9次。现在3次
net.ipv4.tcp_keepalive_probes = 3

#是指TCP发送keepalive消息的频度,默认为7200秒,现在是60秒。
net.ipv4.tcp_keepalive_time = 60

net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 1024 65000
net.ipv4.tcp_max_syn_backlog = 8192
net.ipv4.tcp_max_tw_buckets = 5000
#----------end
生效配置:
sysctl -p

 

 

优化socket性能:
https://yq.aliyun.com/ziliao/56727
在Linux下高并发的Squid服务器中,TCP TIME_WAIT套接字数量经常可达两三万,服务器很容易就会被拖死。不过,我们可以通过修改Linux内核参数来减少Squid服务器的TIME_WAIT套接字数量,命令如下所示:
#vim /etc/sysctl.conf

然后, 增加以下参数:
 代码如下    复制代码
#适用于Squid服务器
net.ipv4.tcp_fin_timeout = 30
net.ipv4.tcp_keepalive_time = 1200
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 1024 65000  
net.ipv4.tcp_max_syn_backlog = 8192
net.ipv4.tcp_max_tw_buckets = 5000

如果是用于Apache或Nginx等的Web服务器,或Nginx的反向代理,则只需要更改以下几项即可:
#适用于Apache或Nginx等web服务器,或Nginx的反向代理
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 1024 65000

如果是邮件服务器,则建议内核方案如下:

#适用于邮件服务器
net.ipv4.tcp_fin_timeout = 30 
net.ipv4.tcp_keepalive_time = 300 
net.ipv4.tcp_tw_reuse = 1 
net.ipv4.tcp_tw_recycle = 1 
net.ipv4.ip_local_port_range = 5000 65000
kernel.shmmax = 134217728

执行以下命令使内核配置立即生效:
#/sbin/sysctl -p
 

你可能感兴趣的:(Centos7)