TCP机制-延迟应答,捎带应答

这篇具有很好参考价值的文章主要介绍了TCP机制-延迟应答,捎带应答。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

        在看本篇博客前推荐先看TCP中窗口和滑动窗口的含义以及流量控制

        延迟应答和捎带应答都是TCP用于提高网络传输效率的机制

延迟应答

        当发送端发送数据给接收端了以后,按道理接收端的内核会立即返回ACK(应答报文)给发送端,而且ACK(应答报文)中不仅含有确认序号,还有接收端接收缓冲区的剩余空间大小,当发送端收到ACK(应答报文)后便可以根据接收端接收缓冲区的剩余空间大小来决定下一轮的窗口大小

        要是接收端一收到请求就返回ACK(应答报文)的话,此时接收端接收缓冲区的剩余空间大小就比较小,此时发送端下一轮的窗口大小也会比较小,效率就比较低,但是实际上在数据传输的这段过程中,接收端接收缓冲区的剩余空间大小可能会被释放一部分,发送端的窗口大小理应比较大。

        所以就有延迟应答的机制,在接收端收到传来的请求以后,并不立即就返回ACK(应答报文)给发送端,而是等待一端时间(程序员规定的时间)再返回ACK(应答报文)给发送端,在等待的这段时间中,接收端接收缓冲区的剩余空间就可能被释放了一部分,此时返回给发送端就可以让发送端下一轮的窗口大小更大一些,效率就更高一些

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

        所有的包都能延时应答吗?

        肯定不是,延迟应答有对应的限制

        1.数量限制(主要针对滑动窗口):每隔N个包就应答一次(因为滑动窗口是批量传输数据,所以在接收ACK应答报文时,后面接收的ACK应答报文能够确认前面发送的数据是成功接收的,所以即使少发几个ACK应答报文也可以,这样的话返回ACK应答报文的频率变低,给了接收端更多处理数据的时间,每次发送端的端口都能更大一些)

        2.时间限制(普通一问一答的发送数据):超过最大的延迟时间就回应一次(在等待的这段时间就给了接收端更多处理数据的时间,这样下一轮发送端的窗口就更大一些,效率就更高一些)

捎带应答

        捎带应答是建立于延迟应答之上的机制,当发送端发送请求给接收端以后,按道理,接收端的内核会立马返回ACK(应答报文)给发送端,然后再处理发送端传来的请求,计算出响应,然后再将响应发送给发送端,这便是两次网络传输数据

        因为有延迟应答机制,接收端在接收到传来的请求时,不会立即的返回ACK(应答报文),而是会等待一端时间,而在这一段时间内,接收端刚好可以对计算出要返回给发送端的响应,计算完毕后,要返回给发送端的ACK(应答报文)就可以捎带着响应一起发送给发送端了

        文章来源地址https://www.toymoban.com/news/detail-669382.html

到了这里,关于TCP机制-延迟应答,捎带应答的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 《TCP/IP网络编程》阅读笔记--基于TCP的服务器端/客户端

    目录 1--TCP/IP协议栈 2--TCP服务器端默认函数调用顺序 3--TCP客户端的默认函数调用顺序 4--Linux实现迭代回声服务器端/客户端 5--Windows实现迭代回声服务器端/客户端 6--TCP原理 7--Windows实现计算器服务器端/客户端         TCP/IP协议栈共分 4 层,可以理解为数据收发分成了 4 个层

    2024年02月10日
    浏览(64)
  • TCP IP网络编程(五) 基于TCP的服务器端、客户端 (补充)

    回声客户端出现的问题 在上一节基于TCP的服务器端、回声客户端中,存在问题: 如果数据太大,操作系统就有可能把数据分成多个数据包发送到客户端,客户端有可能在尚未收到全部数据包时就调用read函数 问题出在客户端,而不是服务器端,先来对比一下客户端与服务器端

    2024年02月09日
    浏览(67)
  • Socket网络编程(TCP/IP)实现服务器/客户端通信。

    一.前言 回顾之前进程间通信(无名管道,有名管道,消息队列,共享内存,信号,信号量),都是在同一主机由内核来完成的通信。 那不同主机间该怎么通信呢? 可以使用Socket编程来实现。 Socket编程可以通过网络来实现实现不同主机之间的通讯。 二.Socket编程的网络模型如

    2024年02月08日
    浏览(89)
  • 《TCP/IP网络编程》阅读笔记--基于UDP的服务器端/客户端

    目录 1--TCP和UDP的主要区别 2--基于 UDP 的数据 I/O 函数 3--基于 UDP 的回声服务器端/客户端 4--UDP客户端Socket的地址分配 5--UDP存在数据边界 6--UDP已连接与未连接的设置 ① TCP 提供的是可靠数据传输服务,而 UDP 提供的是不可靠数据传输服务; ② UDP 在结构上比 TCP 更简洁,其不会

    2024年02月09日
    浏览(61)
  • Linux网络编程之TCP/IP实现高并发网络服务器设计指南

    目录 引言: 多进程服务器 例程分享: 多线程服务器  例程分享: I/O多路复用服务器 select 例程分享: poll 例程分享: epoll 例程分享: 总结建议         随着互联网的迅猛发展,服务器面临着越来越多的并发请求。如何设计一个能够高效处理大量并发请求的服务器成为

    2024年02月20日
    浏览(54)
  • 确认应答机制与超时重发机制【TCP原理(笔记一)】

    在TCP中,当发送端的数据到达接收主机时,接收端主机会返回一个已收到消息的通知。这个消息叫做确认应答(ACK(ACK(Positive Acknowled-gement)意指已经接收。) )。 确认应答机制的基本原理 发送方将数据分割成称为TCP段(TCP segment)的较小单元,并为每个段分配一个唯一的

    2024年02月16日
    浏览(39)
  • Linux TCP/IP内核参数调优,网络高延迟大吞吐(方案二)。

    方案一:Linux TCP/IP内核参数调优,网络高延迟大吞吐。_net.ipv4.tcp_wmem_liulilittle的博客-CSDN博客 nano /etc/sysctl.conf sysctl -p 另类设置

    2024年02月15日
    浏览(76)
  • TCP协议内部工作机制一(确认应答,超时重传,连接管理)

    目录 TCP报文结构 TCP的首部长度 保留(6位) TCP特点 TCP内部的工作机制 一确认应答 超时重传 连接管理 建立建立(三次握手)  TCP断开连接(四次挥手)  TCP的报文结构中, 16位源端口 , 16位目的端口 , 16位校验和和 UDP是一样的,本篇文章就暂不介绍了,可参考俺之前写的UDP协议详解, T

    2023年04月09日
    浏览(81)
  • 《TCP/IP网络编程》阅读笔记--基于Windows实现Hello Word服务器端和客户端

    目录 1--Hello Word服务器端 2--客户端 3--编译运行 3-1--编译服务器端 3-2--编译客户端 3-3--运行 运行结果:

    2024年02月10日
    浏览(66)
  • TCP服务器的演变过程:IO多路复用机制select实现TCP服务器

    手把手教你从0开始编写TCP服务器程序,体验开局一块砖,大厦全靠垒。 为了避免篇幅过长使读者感到乏味,对【TCP服务器的开发】进行分阶段实现,一步步进行优化升级。 本节,在上一章节的基础上,将并发的实现改为IO多路复用机制,使用select管理每个新接入的客户端连

    2024年02月03日
    浏览(59)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包