kernel: TCP: time wait bucket table overflow 问题分析和解决[通俗易懂]

kernel: TCP: time wait bucket table overflow 问题分析和解决[通俗易懂]目录一问题描述二问题分析三问题解决四问题扩展4.1timewait连接过高有什么影响?4.2如何减少timewait连接数?一问题描述工作中的一台数据库打印如下日志:二问题分析查看当时TCP连接数状态:netstat-n|awk’/^tcp/{++S[$NF…

大家好,又见面了,我是你们的朋友全栈君。

目录

一 问题描述       

二 问题分析

三 问题解决

四 问题扩展

4.1 time wait 连接过高有什么影响?

4.2 如何减少 time wait 连接数?


一 问题描述       

       工作中的一台数据库打印如下日志:

kernel: TCP: time wait bucket table overflow 问题分析和解决[通俗易懂]

二 问题分析

       查看当时 TCP 连接数状态: netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’

kernel: TCP: time wait bucket table overflow 问题分析和解决[通俗易懂]

       从图中可以看到 time wait 数据是20143,而机器配置是:

kernel: TCP: time wait bucket table overflow 问题分析和解决[通俗易懂]

 

       得出结论:处于 time wait 状态的 TCP 套接字,超过 net.ipv4.tcp_max_tw_buckets 限制。     

三 问题解决

       适当加大 net.ipv4.tcp_max_tw_buckets 参数值。

四 问题扩展

4.1 time wait 连接过高有什么影响?

       处于 time wait 状态的连接过高时会占用大量连接,可能导致无法创建新的连接,进而影响系统的负载能力。这时需要调整参数,以尽快地释放TIME_WAIT。

4.2 如何减少 time wait 连接数?

一般 TCP 相关的内核参数都在 /etc/sysct1.conf 文件中。为了能够尽快释放 TIME_WAIT 状态的连接,可以做以下配置。

  • 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 Socket 的快速回收,默认值是0,表示关闭。
  • net.ipv4.fin_timeout=10,修改系统默认的 TIMEOUT 时间。

需要注意的一点是,当打开了 tcp_tw_recycle 时,就会检查时间戳,移动环境下发来的包的时间戳有时候是乱跳的,会把带了“倒退”的时间戳的包当做“recycle 的 tw 连接的重传数据,而不是新的请求”,于是丢掉不回包,这样会造成大量丢包。可以考虑设置net.ipv4.timestamps=0,忽略报文的时间戳即可。

此外,还可以通过优化 TCP/IP 的可使用端口的范围,进一步提升负载能力。如下:

  • net.ipv4.tcp_keepalive_time=10,表示当 Keep Alive 启用的时候,TCP 发送 Keep Alive 消息的频度。默认是两小时。
  • net.ipv4.ip_local_port_range=10000 65000,表示用于向外连接的端口范围。默认情况是32768 61000。注意不要将最低值设得太低,否则可能会占用正常的端口。
  • net.ipv4.tcp_max_syn_backlog=8192,表示 SYN 队列的长度,默认值是1024,而加大队列长度为8192可以容纳更多等待连接的网络连接数。
  • net.ipv4.tcp_max_tw_buckets=25000,表示系统同时保持 TIME_WAIT 的最大值,如果超过这个值,TIME_WAIT 会被立刻清除并打印警告信息。

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142680.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm中pip安装地址更改_pycharm怎么安装pip库

    pycharm中pip安装地址更改_pycharm怎么安装pip库pycharm修改pip源为清华源-提高下载速度让PIP源使用国内镜像,提升下载速度和安装成功率。以后文章更新在https://oldpan.me国内pip源:清华大学https://pypi.tuna.tsinghua.edu.cn/simple/在使用pycharm时,…

    2022年8月28日
    5
  • Jmeter—正则表达式提取器:模板&匹配数字详解「建议收藏」

    Jmeter—正则表达式提取器:模板&匹配数字详解「建议收藏」目录一、相关理论1.正则表达式2.模板3.匹配数字二、例子1.【模板&匹配数字】2.【例-贪婪&非贪婪】3.【例-普通】一、相关理论1.正则表达式():要提取的内容.:匹配任意单个字符串*:匹配(之前的符号)0次或多次+:匹配(+之前的符号)1次或多次?:不要太贪婪,在找到第一个匹配项后停止。.:匹配连续0个/多个字符.+:匹配连续1个/多个字符\:转义,.表示匹配字符.本身2.模板表示取哪几个括号中的值若模板为:000,则为整个表达式匹配到的内容(这里为整个响

    2025年10月18日
    2
  • SVN汉化包安装后无效果(已解决)「建议收藏」

    SVN汉化包安装后无效果(已解决)「建议收藏」SVN汉化包安装后无效果(已解决)上图是我下载的SVN客户端的版本。下图是汉化包版本然后我就按部就班的一步一步安装,但始终不能设置语言为中文后来才知道是版本不对,汉化包和客户端版本要一致才行。最后我重新下了一个版本的汉化包再安装(我就把汉化包下载在桌面上,然后点击安装的),问题解决。如下图:相关链接SVN客户端下载地址:https://tortoisesvn.net/downloa…

    2025年7月24日
    5
  • QT QMap介绍与使用「建议收藏」

    QT QMap介绍与使用「建议收藏」Qt中的QMap介绍与使用,在坛子里逛了一圈,发现在使用QMap中,出现过很多的问题,Map是一个很有用的数据结构。它以“键-值”的形式保存数据。在使用的时候,通过提供字符标示(键)即可得到想要的数据。这个“数据”即可以是一个字符串,也可以是任意对象,当然也包括自己定义的类对象。说明:map是以值传递的形式保存数据的。1.基本应用下面以“键-值”都是QString的例子说明QMa

    2022年5月30日
    66
  • internal server error是什么意思?

    internal server error是什么意思?internalservererror错误通常发生在用户访问网页的时候发生,该错误的意思是因特网服务错误。能够引起internalservererror报错的原因有多个,如果你是网站主的话,可以对下列情形进行一一排查。  1.服务器资源超载。如果网站文件没有做过修改,最有可能的是同服务器的资源超载:即同一时间内处理器有太多的进程需要处理的时候,会出现500错误。借助SSH,可以在命令行中输入以下命令查看:psfauxpsfaux|grepusername如果你查到某个进程消耗过多资源,

    2022年7月12日
    48
  • python对奇异矩阵求逆_奇异矩阵-python

    python对奇异矩阵求逆_奇异矩阵-python下面的代码显示了一个矩阵的奇点问题 因为我在 Pycharm 中工作 raiseLinAlgE Singularmatr numpy linalg linalg LinAlgError Singularmatr 我想问题是 K 但我不能确切地理解如何 fromnumpyimp linalgimport

    2025年9月22日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号