当前位置:   article > 正文

Centos7 TCP断线系统检测时间配置及TCP服务器优化_net.ipv4.tcp_keepalive_intvl = 10

net.ipv4.tcp_keepalive_intvl = 10

 

配置客户端异常断线检测时间
代码中:((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
 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/158569?site
推荐阅读
相关标签
  

闽ICP备14008679号