TCP延迟应答、捎带应答、粘包问题、异常处理

导读:本篇文章讲解 TCP延迟应答、捎带应答、粘包问题、异常处理,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

一、延迟应答

上篇博客我们讲到TCP滑动窗口、流量控制、拥塞控制

如果接收数据的主机立刻返回ACK应答,这时候返回的窗口可能比较小。
在这里插入图片描述

窗口越大,网络吞吐量就越大,传输效率就越高。我们的目标是在保证网络不拥塞的情况下尽量提高传输效率~~

那么所有的包都可以延迟应答么?肯定也不是:(具体的数量和超时时间,依操作系统不同也有差异)

  • 数量限制:每隔N个包就应答一次
  • 时间限制:超过最大延迟时间就应答一次

在这里插入图片描述

二、捎带应答

在延迟应答的基础上我们发现,很多情况下客户端服务器在应用层也是 “一发一收” 的。意味着客户端给服务器说了”How are you”,服务器也会给客户端回一个”Fine, thank you”,那么这个时候ACK就可以搭顺风车,和服务器回应的”Fine,thank you”一起回给客户端~~
在这里插入图片描述

所以在一些场景下,四次挥手断开连接可能变为”三次”~~

三、面向字节流 – 粘包问题

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

四、TCP中的异常处理

  1. 程序崩溃了
    进程异常退出~ 操作系统会回收进程的资源,包括释放文件描述符表。这样的释放操作就相当于调用了对应socket的close,执行close就会触发FIN报文,进一步开始四次挥手。
    这种情况和普通的四次挥手其实没啥区别~~
  2. 正常关机 (通过开始菜单这种方式来关闭主机)
    关机的时候系统会先强制结束所有的用户进程,和上述的那个进程崩溃类似。系统内核会进行文件描述符的释放操作,进一步进行四次挥手~~
  3. 主机掉电
    可能伤硬盘~
    1)掉电的是接收方。发送方不知道对面挂了,继续发数据,此时发的数据没有ACK了。发送方触发超时重传,重传几次之后仍然无应答,尝试重置连接 (复位报文段),也会失败。只能放弃连接了~~
    在这里插入图片描述
    2)掉电的是发送方。此时接收方就等着,但接收方也不是干等,等了一阵之后,就会发送一个”心跳包” !心跳包是周期性触发的:只是一个简单的不携带任何业务数据的包,存在的意义就是确认一下对方是否还在。如果对方不返回心跳包,就说明心跳遗失,说明对方挂了,此时也就会放弃连接了~~
  4. 网线断开
    情况同主机掉电,只不过通信双方的主机都是好着呢,这两端各自按照上述讲的两种情况分别进行~~

五、补充

在这里插入图片描述


在这里插入图片描述

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

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/118571.html

(0)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!