1、优化示例仅供参考
net.ipv4.tcp_max_tw_buckets = 6000
net.ipv4.ip_local_port_rang = 1024 65000
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_syncookies = 1
net.core.somaxconn = 262144
net.core.netdev_max_backlog = 262144
net.ipv4.tcp_max_orphans = 262144
net.ipv4.tcp_max_syn_backlog = 262144
net.ipv4.tcp_synack_retries = 1
net.ipv4.tcp_syn_retries = 1
net.ipv4.tcp_fin_timeout = 1
net.ipv4.tcp_keepalive_time = 30
将上面内核参数值加入 /etc/sysctl.conf文件中
2、示例中选项含义如下:
net.ipv4.tcp_max_tw_buckets 参数用来设定timewait的数量,默认是18000,这里设定为6000
net.ipv4.ip_local_port_rang 选项用来设定允许系统打开的端口范围
net.ipv4.tcp_tw_recycle 选项用于设置启动timewait快速回收
net.ipv4.tcp_tw_reuse 选项用于设置开启重用,允许将TIME-WAIT sockets重新用于新的TCP连接
net.ipv4.tcp_syncookies 选项用于设置开启SYN cookies,当出现SYN等待队列溢出持续,启用cookies进行处理
net.core.somaxconn 这个参数用于调节系统同时发起的TCP连接数,在高并发的请求中,默认值128可能会导致连接超时或者重传,因此需要结合并发请求数来调节此值
net.core.netdev_max_backlog 选项表示当每个网络接口接收数据包的速率比内核处理这些包的速率快时,允许发送到队列的数据包最大数目
net.ipv4.tcp_max_orphans 选项用于设定系统中最多有多少个TCP套接字不被关联到任何一个用户文件句柄上。如果超过这个数字,孤立连接将立即被复位并输出警告信息。这个限制只是为了防止简单的DoS攻击。不能过分依靠这个限制甚至人为减小这个值,更多的情况是增加这个值
net.ipv4.tcp_max_syn_backlog 选项用于记录那些尚未收到客户端确认信息的连接请求的最大值。对于128MB内存的系统而言,此参数的默认值是1024,对于小内存的系统则是128
net.ipv4.tcp_synack_retries 参数的值决定了内核放弃连接之前发送SYN+ACK包的数量
net.ipv4.tcp_syn_retries 选项表示在内核放弃建立连接之前发送SYN包的数量
net.ipv4.tcp_fin_timeout 选项决定了套接字保持在FIN-WAIT2状态的时间。默认值是60秒,正确设置这个值非常重要,有时候即使一台负责很小的Web服务器,也是会出现因为大量的死套接字而产生内存溢出的风险
net.ipv4.tcp_keepalive_time 选项表示当Keepalive启用的时候,TCP发送keepalive消息的频率。默认值是2小时
linux