共计 1775 个字符,预计需要花费 5 分钟才能阅读完成。
操作系统内核参数优化
net.ipv4.tcp_max_tw_buckets = 6000
net.ipv4.ip_local_port_range = 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 文件中,并执行
/sbin/sysctl -p
使配置生效。
解释:
net.ipv4.tcp_max_tw_buckets 选项用来设定 timewait 的数量,默认是 180 000,这里设为 6000。
net.ipv4.ip_local_port_range 选项用来设定允许系统打开的端口范围。
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 选项的默认值是 128,这个参数用于调节系统同时发起的 tcp 连接数,在高并发的请求中,默认的值可能会导致链接超时或者重传,因此,需要结合并发请求数来调节此值。
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-WAIT- 2 状态的时间。默认值是 60 秒。正确设置这个值非常重要,有时即使一个负载很小的 Web 服务器,也会出现大量的死套接字而产生内存溢出的风险。
net.ipv4.tcp_syn_retries 选项表示在内核放弃建立连接之前发送 SYN 包的数量。
如果发送端要求关闭套接字,net.ipv4.tcp_fin_timeout 选项决定了套接字保持在 FIN-WAIT- 2 状态的时间。接收端可以出错并永远不关闭连接,甚至意外宕机。
net.ipv4.tcp_fin_timeout 的默认值是 60 秒。需要注意的是,即使一个负载很小的 Web 服务器,也会出现因为大量的死套接字而产生内存溢出的风险。FIN-WAIT- 2 的危险性比 FIN-WAIT- 1 要小,因为它最多只能消耗 1.5KB 的内存,但是其生存期长些。
net.ipv4.tcp_keepalive_time 选项表示当 keepalive 启用的时候,TCP 发送 keepalive 消息的频度。默认值是 2(单位是小时)。
本文出自“ 运维之道 ”博客,请务必保留此出处 http://pesen.blog.51cto.com/4575807/1137946
