0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

为什么建链接要3次握手,断链接需要4次挥手?

Linux爱好者 来源:Jack 作者:Linux爱好者 2020-11-12 15:36 次阅读

首先处理这个问题,我们要知道一些网络知识,要知道tcp那些事,比如说三次握手,和四次挥手......很多人会问,为什么建链接要3次握手,断链接需要4次挥手?让我们一起看下下面的流程图:

首先,是三次握手:

首先Client端发送连接请求报文,Server段接受连接后回复ACK报文,并为这次连接分配资源。Client端接收到ACK报文后也向Server段发生ACK报文,并分配资源,这样TCP连接就建立了。

然后是中间部分:两者之间可以传输数据了

再次,下面的断开链接:【注意】中断连接端可以是Client端,也可以是Server端。

假设Client端发起中断连接请求,也就是发送FIN报文。Server端接到FIN报文后,意思是说"我Client端没有数据要发给你了",但是如果你还有数据没有发送完成,则不必急着关闭Socket,可以继续发送数据。

所以你先发送ACK,"告诉Client端,你的请求我收到了,但是我还没准备好,请继续你等我的消息"。这个时候Client端就进入FIN_WAIT状态,继续等待Server端的FIN报文。当Server端确定数据已发送完成,则向Client端发送FIN报文,"告诉Client端,好了,我这边数据发完了,准备好关闭连接了"。

Client端收到FIN报文后,"就知道可以关闭连接了,但是他还是不相信网络,怕Server端不知道要关闭,所以发送ACK后进入TIME_WAIT状态,如果Server端没有收到ACK则可以重传。“,Server端收到ACK后,"就知道可以断开连接了"。Client端等待了2MSL后依然没有收到回复,则证明Server端已正常关闭,那好,我Client端也可以关闭连接了。Ok,TCP连接就这样关闭了!

那么可以这么理解,当client进入time_wait的等待时间是2个MSL

让我们看一下一台linux服务器的网络状态:

# netstat -an | awk '/^tcp/ {++State[$NF]}END{for(key in State)print key " " State[key]}'LAST_ACK 7LISTEN 9SYN_RECV 2CLOSE_WAIT 125ESTABLISHED 1070FIN_WAIT1 17FIN_WAIT2 247CLOSING 4TIME_WAIT 25087

对于网站来说,这样的time_wait略显偏高, 也就是说大量的关闭操作在等待2个MSL后结束,正常我们的tcp 端口是65535个,如果并发再高一些,可能会大量的socket不能及时被释放,从而导致性能下降,所以我们可以通过linux内核进行一些网络调整比如,开启socket重用和快速回收:

net.ipv4.tcp_syncookies = 1net.ipv4.tcp_tw_reuse = 1net.ipv4.tcp_tw_recycle = 1net.ipv4.tcp_max_tw_buckets = 5000net.ipv4.tcp_max_syn_backlog = 8192net.ipv4.tcp_keepalive_time = 1200net.ipv4.ip_local_port_range = 1024 65000

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 sockets的快速回收,默认为0,表示关闭。

系统tcp_timestamps缺省就是开启的,所以当tcp_tw_recycle被开启后,实际上这种行为就被激活了.如果服务器身处NAT环境,安全起见,通常要禁止tcp_tw_recycle,至于TIME_WAIT连接过多的问题,可以通过激活tcp_tw_reuse来缓解。

net.ipv4.tcp_max_tw_buckets = 5000

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

net.ipv4.tcp_max_syn_backlog = 8192

表示SYN队列的长度,默认为1024,加大队列长度为8192,可以容纳更多等待连接的网络连接数。

net.ipv4.tcp_keepalive_time = 1200

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

net.ipv4.ip_local_port_range = 1024-65000

表示用于向外连接的端口范围。缺省情况下很小:32768到61000,改为1024到65000。

# netstat -an | awk '/^tcp/ {++State[$NF]}END{for(key in State)print key " " State[key]}' LAST_ACK140 LISTEN9 SYN_RECV7 CLOSE_WAIT2 ESTABLISHED972 FIN_WAIT121 FIN_WAIT2152 CLOSING2 TIME_WAIT682

责任编辑:lq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    10988

    浏览量

    206725
  • 服务器
    +关注

    关注

    12

    文章

    8111

    浏览量

    82496
  • TCP
    TCP
    +关注

    关注

    8

    文章

    1270

    浏览量

    78282

原文标题:Linux TCP 状态 TIME_WAIT 过多的处理

文章出处:【微信号:LinuxHub,微信公众号:Linux爱好者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    链接与硬链接的区别

    链接又叫符号链接,和原文件不是一个文件,类似Windows的快捷方式,如果原始文件被删除,所有指向它的符号链接也就都被破坏了
    的头像 发表于 04-19 10:09 69次阅读
    软<b class='flag-5'>链接</b>与硬<b class='flag-5'>链接</b>的区别

    STM32+LWIP通信12无法再次通信怎么解决?

    尝试移植LWIP+FREERTOS的时候出现了如下问题,请各位大佬帮忙看看是哪里的问题,我用了FreeRTOS+LWIP做ModbusTCP时出现了链接出现通信12然后通信中断,并且再也没法
    发表于 04-12 07:42

    Linux中的软、硬链接的区别

    /inittab /test/inittab.hard   发现硬链接与真实文件的大小和创建日期完全相同,类似于copy,同步更新。   3:硬链接与拷贝的区别:   发现拷贝与真实文件的创建日期
    发表于 02-04 16:34

    NUC980新做的板子使用USB0启动,计算机链接不上是怎么回事?

    做了3板子,都是4层板。打算用USB烧写程序,链接计算机时,每次报 “设备描述符请求失败”的错误。最后一把USB0 连接到一个1.25间
    发表于 01-17 07:47

    u-boot armv8链接脚本

    u-boot armv8链接脚本 在进行源码分析之前,首先看看u-boot的链接脚本,通过链接脚本可以从整体了解一个u-boot的组成,并且可以在启动分析中知道某些逻辑是在完成什么工作
    的头像 发表于 12-07 11:19 243次阅读

    RS232转PROFINET网关链接扫码枪

    RS232转PROFINET网关,实现固定式超市收银扫码机与PLC之间的无缝链接
    的头像 发表于 11-24 11:21 372次阅读
    RS232转PROFINET网关<b class='flag-5'>链接</b>扫码枪

    链接PK软链接

    链接PK软链接
    的头像 发表于 10-12 18:16 801次阅读

    长短链接原理案例

    最近在做一套推广系统,将其中涉及的 长短链接问题 在这里分享一下。推广方式主要是以短信方式慰问客户并推送宣传链接(非广告),但链接真的是太长了,先不说短信按字数收费问题,就是看到就想立刻删除。所以
    的头像 发表于 10-08 14:31 370次阅读
    长短<b class='flag-5'>链接</b>原理案例

    关于STM32CubeIDE链接脚本的小问题

    电子发烧友网站提供《关于STM32CubeIDE链接脚本的小问题.pdf》资料免费下载
    发表于 09-20 11:25 0次下载
    关于STM32CubeIDE<b class='flag-5'>链接</b>脚本的小问题

    ARM编译器工具链的动态链接应用说明

    动态链接是一个复杂的主题,通常只有部分人了解。 理解ARM编译器工具链中的动态链接,您不仅需要良好的动态链接背景知识,还
    发表于 08-29 06:48

    互联网短链接服务系统设计要点

    链接服务将原本较长的网址转化成较短的网址,从而便于用户的记忆与社交软件上的传播。
    的头像 发表于 08-25 10:57 536次阅读
    互联网短<b class='flag-5'>链接</b>服务系统设计要点

    C语言的编译链接过程

      C语言的编译链接过程要把我们编写的一个C程序源代码转换成可以在硬件上运行的程序(可执行代码),需要进行编译和链接。编译就是把文本形式源代码翻译为机器语言形式的目标文件的过程。链接
    的头像 发表于 08-21 10:06 1612次阅读
    C语言的编译<b class='flag-5'>链接</b>过程

    如何链接Spice模型

    尽管设计中的所有元件均须链接模型,且编译器亦可进行验证,但确保这些链接模型的管脚与相应原理图符号正确映射更为关键,因为如果现有管脚映射不符合预期,则编译器无法自动进行解码和标记。
    的头像 发表于 07-14 09:48 516次阅读
    如何<b class='flag-5'>链接</b>Spice模型

    NUC980新做的板子使用USB0启动,计算机链接不上是怎么回事?

    做了3板子,都是4层板。打算用USB烧写程序,链接计算机时,每次报 “设备描述符请求失败”的错误。最后一把USB0 连接到一个1.25间
    发表于 06-28 08:05

    NUC980新做的板子使用USB0启动,计算机链接不上怎么解决?

    做了3板子,都是4层板。打算用USB烧写程序,链接计算机时,每次报 “设备描述符请求失败”的错误。最后一把USB0 连接到一个1.25间
    发表于 06-13 09:54