修改Linux内核参数,减少TCP连接中的TIME-WAIT

2023-10-27

一台服务器CPU和内存资源额定有限的情况下,如何提高服务器的性能是作为系统运维的重要工作。要提高Linux系统下的负载能力,当网站发展起来之后,web连接数过多的问题就会日益明显。在节省成本的情况下,可以考虑修改Linux的内核TCP/IP参数来部分实现;如果通过修改内核参数也无法解决的负载问题,也只能考虑升级服务器了。

Linux系统下,TCP/IP连接断开后,会以TIME_WAIT状态保留一定的时间,然后才会释放端口。当并发请求过多的时候,就会产生大量的TIME_WAIT状态的连接,无法及时断开的话,会占用大量的端口资源和服务器资源(因为关闭后进程才会退出)。这个时候我们可以考虑优化TCP/IP的内核参数,来及时将TIME_WAIT状态的端口清理掉。

本文介绍的方法只对拥有大量TIME_WAIT状态的连接导致系统资源消耗有效,不是这个原因的情况下,效果可能不明显。那么,到哪儿去查TIME_WAIT状态的连接呢?那就是使用netstat命令。我们可以输入一个复核命令,去查看当前TCP/IP连接的状态和对应的个数:
# netstat -an | awk '/^tcp/ {++s[$NF]} END {for(a in s) print a,s[a]}'

这个命令会显示出类似下面的结果:
TIME_WAIT 63648
FIN_WAIT1 3
FIN_WAIT2 4
ESTABLISHED 184
LISTEN 17

我们只用关心TIME_WAIT的个数,在这里可以看到,有6w多个TIME_WAIT,这样就占用了6w多个端口。要知道端口的数量只有65535个,占用一个少一个,会严重的影响到后继的新连接。这种情况下,我们就有必要调整下Linux的TCP/IP内核参数,让系统更快的释放TIME_WAIT连接。

我们用vim打开配置文件:
# vim /etc/sysctl.conf

然后,在这个文件中,加入下面的几行内容:
   net.ipv4.tcp_syncookies = 1
   net.ipv4.tcp_tw_reuse = 1
   net.ipv4.tcp_tw_recycle = 1
   net.ipv4.tcp_fin_timeout = 5

最后输入下面的命令,让内核参数生效:
# /sbin/sysctl -p

简单的说明下,上面的参数的含义:
net.ipv4.tcp_syncookies = 1 表示开启SYNCookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;

net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAITsockets重新用于新的TCP连接,默认为0,表示关闭;

net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAITsockets的快速回收,默认为0,表示关闭;

net.ipv4.tcp_fin_timeout 修改系统默认的 TIMEOUT 时间。

在经过这样的调整之后,除了会进一步提升服务器的负载能力之外,还能够防御一定程度的DDoS、CC和SYN攻击,是个一举两得的做法。

此外,如果你的连接数本身就很多,我们可以再优化一下TCP/IP的可使用端口范围,进一步提升服务器的并发能力。依然是往上面的参数文件中,加入下面这些配置:
   net.ipv4.tcp_keepalive_time = 1200
   net.ipv4.ip_local_port_range = 10000 65000
   net.ipv4.tcp_max_syn_backlog = 8192
   net.ipv4.tcp_max_tw_buckets = 5000

这几个参数,建议只在流量非常大的服务器上开启,会有显著的效果。一般的流量小的服务器上,没有必要去设置这几个参数。这几个参数的含义如下:

net.ipv4.tcp_keepalive_time = 1200表示当keepalive起用的时候,TCP发送keepalive消息的频度。缺省是2小时,改为20分钟。

net.ipv4.ip_local_port_range = 10000 65000表示用于向外连接的端口范围。缺省情况下很小:32768到61000,改为10000到65000。(注意:这里不要将最低值设的太低,否则可能会占用掉正常的端口!)
net.ipv4.tcp_max_syn_backlog = 8192表示SYN队列的长度,默认为1024,加大队列长度为8192,可以容纳更多等待连接的网络连接数。

net.ipv4.tcp_max_tw_buckets = 5000表示系统同时保持TIME_WAIT的最大数量,如果超过这个数字,TIME_WAIT将立刻被清除并打印警告信息。默认为180000,改为5000。对于Apache、Nginx等服务器,上几行的参数可以很好地减少TIME_WAIT套接字数量,但是对于Squid,效果却不大。此项参数可以控制TIME_WAIT的最大数量,避免Squid服务器被大量的TIME_WAIT拖死。

经过这样的配置之后,你的服务器的TCP/IP并发能力又会上一个新台阶。在存在大量短连接的情况下,Linux的TCP栈一般都会生成大量的TIME_WAIT 状态的socket。
# netstat -ant|grep -i time_wait |wc -l

可能会超过三四万。这个时候,我们需要修改 linux kernel 的 tcp time wait的时间,有个 sysctl参数貌似可以使用,它是 /proc/sys/net/ipv4/tcp_fin_timeout,缺省值是60,也就是60秒,很多网上的资料都说将这个数值设置低一些就可以减少netstat里面的TIME_WAIT状态,但是这个说法不是很准确的。经过认真阅读Linux的内核源代码,我们发现这个数值其实是输出用的,修改之后并没有真正的读回内核中进行使用,而内核中真正管用的是一个宏定义,在$KERNEL/include/net/tcp.h里面,有下面的行:
      #defineTCP_TIMEWAIT_LEN (60*HZ)
      而这个宏是真正控制TCP TIME_WAIT 状态的超时时间的。如果我们希望减少 TIME_WAIT状态的数目(从而节省一点点内核操作时间),那么可以把这个数值设置低一些,根据我们的测试,设置为 10秒比较合适,也就是把上面的修改为:
      #defineTCP_TIMEWAIT_LEN (10*HZ)

  然后重新编译内核,重启系统即可发现短连接造成的TIME_WAIT状态大大减少:
  netstat -ant | grep -i time_wait |wc -l
  一般情况都可以至少减少2/3。也能相应提高系统应对短连接的速度


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

修改Linux内核参数,减少TCP连接中的TIME-WAIT 的相关文章

  • 每日一题 AcWing 99.激光炸弹

    题目 地图上有 N 个目标 用整数 Xi Yi 表示目标在地图上的位置 每个目标都有一个价值 Wi 注意 不同目标可能在同一位置 现在有一种新型的激光炸弹 可以摧毁一个包含 R R 个位置的正方形内的所有目标 激光炸弹的投放是通过卫星定位的
  • 用matplotlib画圆和圆环

    usr bin env python coding UTF 8 import numpy as np from pylab import 创建一个 8 8 点 point 的图 并设置分辨率为 80 figure figsize 8 8 d
  • vsan加入不同型号服务器,VMware VSAN的特点与要求,与优缺点

    VSAN的特点与要求 与优缺点 VMware VSAN主要有5个特点 1 运行在标准x86服务器上 2 分布式集群 把VM数据文件打散放在多个主机上 每个服务器的本地存储网络池化3 使用SSD作为读写缓存加速层 混合型策略 由SSD提供性能
  • 剑指offer_第6题_旋转数组的最小数字

    题目描述 把一个数组最开始的若干个元素搬到数组的末尾 我们称之为数组的旋转 输入一个非减排序的数组的一个旋转 输出旋转数组的最小元素 例如数组 3 4 5 1 2 为 1 2 3 4 5 的一个旋转 该数组的最小值为1 给出的所有元素都大于
  • 机器学习笔记七:使用主成分分析(PCA)对数据集进行降维

    一 前言 有时候我们遇到的一些数据会有很多的特征 几十个 甚至成千上百个 由于此时特征较多 就大大增加了计算的复杂度 鉴于并非所有的特征都非常重要 也为了减少计算的复杂度 我们有必要对数据进行降维 以iris数据集为例 我们都知道 iris
  • python绘制折线图

    俗话说 字不如表 表不如图 图表在数据分析中的作用不言而喻 python中有pandas和matplotlib两个库供使用者来绘制图表 下面来绘制 成绩表 xlsx 的折线图 废话不多说 直接上代码 import pandas as pd
  • 入坑c计划 day3 基本框架的介绍&&输入语法

    我giao 兄弟蒙 我来更新了doge 为了弥补我托更 咱今天加班更新一下新手题型 加油 今天 我们来介绍我们上一节提到的 基本框架 首先 我们先和这个朋友再见个面 怕你们忘记他长什么样子 include
  • 用python制作水仙花

    注 input 输入函数的括号中不允许添加任何信息 提示信息 水仙花数 是指一个三位正整数 其各位数字立方的和等于该数本身 例如 153是一个 水仙花数 因为1 5 3等于153 编程实现 给定一个正整数N 判断100到N之间有多少个 水仙
  • Java---正则

    一 正则表达式常用语法 语法 说明 表示转义字符 匹配输入字符串的开始 匹配输入字符串的结尾 0次或多次匹配前面的字符或表达式 1次或多次匹配前面的字符或表达式 0次或1次匹配前面的字符或表达式 n n为非负整数 固定匹配n次 n n为非负
  • 刷脸支付开启巨额补贴活动扶持力度非常大

    人脸识别设备指纹识别系统需要区别带识别的指纹是来自于人的手指还是指纹手套 人脸识别系统所采集到的人脸图像 是来自于真实的人脸还是含有人脸的照片 因此实际的人脸识别系统一般需要增加活体鉴别环节 例如 要求人左右转头 眨眼睛 开开口说句话等 这
  • jenkins发版工具管理

    从零开始部署一台新的服务器 需要以下几个步骤 1 新增服务器凭据 2 新增服务器连接 3 创建item项目并配置 4 测试发版是否完成 1 新增服务器凭据配置 进入链接 http jenkins地址 credentials store sy
  • 线程的阻塞

    相信像我一样的初学者遇到线程阻塞时会感到无助 那我就把自己对于线程阻塞的理解记录下来吧 线程阻塞时的特点 该线程放弃CPU的使用权 暂停运行 只有当阻塞的原因消除后才回到就绪状态进行运行 被其他的线程中断 该线程也会推出阻塞状态 同时抛出I
  • stable diffusion实践操作-提示词插件安装与使用

    本文专门开一节写提示词相关的内容 在看之前 可以同步关注 stable diffusion实践操作 正文 1 提示词插件安装 1 1 安装 1 2 加载 应用更改并重载前端 1 3 界面展示 点击下面红框按钮 可以出现提示词列表 1 4 使
  • Latex中点乘、希腊字母、花写字体等

    Latex中点乘 希腊字母等 Latex中点乘 希腊字母等 Latex中的乘法 希腊字母表 花写字体 Latex中点乘 希腊字母等 使用Latex进行公式编辑时 由于某些符号不经常用到 老是忘记 所以谢一篇文章来总结 记录一下 Latex中
  • Go 语言性能测试 - 入门篇

    Go 语言性能测试 入门篇 Go 语言是非常高效的 在处理并发请求时的性能表现非常出色 在某些考虑性能因素的场景下 我们需要进行性能测试 Go语言提供了用于性能测试的 testing B 框架 本篇就介绍下Go语言的性能测试的基本做法 参考
  • python实现斐波那契数列

    斐波那契数列指的是这样一个数列 0 1 1 2 3 5 8 13 特别指出 第0项是0 第1项是第一个1 从第三项开始 每一项都等于前两项之和 Python 实现斐波那契数列代码如下 实现一 1 def fibonacci 2 num in
  • 服务器的架构有哪些

    服务器的架构有哪些 1 单体架构 软件设计经典的3层模型是表现层 业务逻辑层 数据访问层 典型的单体架构就是将所有的业务场景的表现层 业务逻辑层 数据访问层放在一个工程中最终经过编译 打包 部署在一台服务器上 2 垂直架构 垂直架构是将一个
  • nRF52832 — UART和指纹模块

    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XX 作 者 文化人 XX 联系方式 XX 版权声明 原创文章 欢迎评论和转载 转载时能告诉我一声就最好了 XX 要说的
  • 基于python的在线考试系统-提供全套Python教学资源和考试系统,全力打造良心服务...

    原标题 提供全套Python教学资源和考试系统 全力打造良心服务 书名 Python程序设计基础 第2版 书号 9787302490562 出版单位 清华大学出版社 适用Python版本 Python 3 4 3 5 3 6 3 7以及更新
  • 计算机基础及ms office应用,计算机基础及MS Office应用知识

    NCRE考试实行百分制计分 但以等第通知考生成绩 等第共分优秀 及格 不及格三等 以下是关于计算机基础及MS Office应用知识 希望大家认真阅读 1 计算机网络与数据通信 人们对计算机网络提出了不同的定义 当前较为准确的定义为 以能够相

随机推荐

  • 空列表不等同于None

    ss if ss is not None print None1 ss None if ss is not None print None2 输出结果 None1
  • 编译libfcitxplatforminputcontextplugin.so解决Qt5在Linux上无法输入中文的问题

    环境 deepin 15 11 Qt 5 12 4 文中涉及到的Qt路径需要根据自己安装的版本自行更改 安装Git 获取fcitx qt5源码 sudo apt install git git clone http github com f
  • 卷积神经网络学习利器CNN Explainer

    CNN解说员 一个交互式可视化系统 旨在帮助非专家了解卷积神经网络 CNN 有关更多信息 请查看我们的手稿 CNN 解释器 通过交互式可视化学习卷积神经网络 Wang Zijie J Robert Turko Omar Shaikh Hae
  • 华为eNSP 三层交换机配置使用vlan及ospf通信

    实验拓扑图如下 提前配置好主机ip地址及端口ip地址 备注 接PC 路由器 服务器的接口一般用access LSW8三层交换机的配置 sysname LSW8 vlan batch 20 30 40 interface Vlanif1 in
  • 对于std::vector的等号重载操作符的理解

    1 对于case 1 赋值重载 比如当前的vector的allocator type是这样的 std allocator traits
  • VS2015+Qt5.9.1+Mysql5.7.25开发环境搭建

    VS2015 Qt5 9 1 Mysql5 7 25开发环境搭建 版本信息 版本 作者 时间 备注 v0 1 ZY 2019 3 2 初稿 目录 文章目录 VS2015 Qt5 9 1 Mysql5 7 25开发环境搭建 版本信息 目录 一
  • 机器学习:LDA_数学基础_2:贝叶斯数学:先验分布的选择

    先验信息确定先验分布 主观概率 对事件似然比 专家意见 历史资料 无信息先验分布 贝叶斯假设 离散均匀分布 有限区间的均匀分布 广义分布 共轭先验分布 在已知样本的情况下 为了理论的需要 常常选择参数的分布为共轭先验分布 最大熵先验分布 无
  • fork父子进程共享

    fork之后 子进程会拷贝父进程的数据空间 堆和栈空间 实际上是采用写时复制技术 二者共享代码段 所以在子进程中修改全局变量 局部变量 分配在堆上的内存同样也是 后 父进程的相同的全局变量不会改变 见下面代码分析 include
  • python3.6 print同一行覆盖打印

    1 python3 6中 print同一行覆盖打印可以这样使用 通用 print r object end flush True 例子 print r loss G 0 3f format loss G item end flush Tru
  • overleaf latex常用指令

    文字 bf 加粗 textit 斜体 emph 强调文本 另外 百分号 双引号 前双引号点两次 左上角1旁边的键 后双引号点两次 enter旁边的键 注意 这个符号 有时候可能是中文的 报错 上标 字母 上标 下标 字母 下标 表格 宏包
  • 7.11项目进度

    学习内容 AE课程一节 复习回顾AE课程并整理笔记 学习时间 上午8 00 11 00 下午3 00 5 00 遇到问题 在学习和制作作业的过程中 我发现自己存在严重的学习知识不牢固的问题 因此在今后学习中 我会增加课堂笔记这一学习内容 从
  • 记一次静态工具类单元测试用例

    代码中有用到自己创建的工具类BeanContext来获取当前上下文 以下是代码 package com sap calm imp ca ana da util import org springframework beans BeansEx
  • centos7使用说明

    说在前面 俗话说好记性不如烂笔头 考虑到每次安装部署都要各种查阅资料 很是不便 故决定重头开始安装一遍常用服务 作为以后的参照 第一步 确定发行版本 安装系统 首先明确自己需要的版本 本人不习惯桌面版 作为服务器 推荐熟悉命令行系统 毕竟效
  • 2020年的第二周

    2020年的第2周 2020年1月6日 2020年1月12日 上周和朋友出去聚餐 A说让我们带着她炒股 她赚点小钱 我说我在玩基金 赚了个几百 C说 他爸爸定投基金10年每个月3000才赚了五万 要就赚大钱 不搞这些基金 我们就聊啊聊 比如
  • 基于STM32和超声波模块的超声波测距,使用OLED显示距离和温度(附详细源代码)

    1 HC SR04模块介绍 HC SR04模块优势 此模块性能稳定 测度距离精确 模块高精度 盲区小 产品应用领域 1 机器人避障 2 物体测距 3 液位检测 4 公共安防 5 停车场检测 超声波测距模块工作原理 1 采用IO口TRIG触发
  • Autofac +webapi 配置

    Autofac配置 using Autofac using System using System Collections Generic using System Linq using System Reflection using Sy
  • mybatis日志打印大杀器

    文章目录 前言 MybatisLogFormat 选项一 选项二 缺点 Mybatis Log Free 总结 前言 各位精通CRUD的老司机 相信大家在工作中mybatis或者mybatisplus使用的肯定是比较多的 那么大家或多或少都
  • List知识总结

    ArrayList 1 ArrayList扩容底层用到的是 System arraycopy 2 扩容的长度计算 int newCapacity oldCapacity oldCapacity gt gt 1 旧容量 旧容量右移1位 这相当
  • 鼠标右键 自定义

    1 在需要添加右键的页面 绑定contextmenu事件 阻止浏览器默认事件 添加自定义事件
  • 修改Linux内核参数,减少TCP连接中的TIME-WAIT

    一台服务器CPU和内存资源额定有限的情况下 如何提高服务器的性能是作为系统运维的重要工作 要提高Linux系统下的负载能力 当网站发展起来之后 web连接数过多的问题就会日益明显 在节省成本的情况下 可以考虑修改Linux的内核TCP IP