Java TCP协议(2)

TCP可靠传输

五. 流量控制

用来控制发送方的窗口大小,通过接收方返回来的ACK进行反制。

接收方把自己能够处理的数据量主动告诉发送方,从而让发送方动态调整窗口大小。

如果窗口大小为0表示没有空间去接收数据了,主机A就不发数据了,导致主机B就没有后续的ACK了,也就意味着双发停止通讯了。

过了重发超时以后若还没有收到窗口更新的通知,发送端会发送一个窗口探测的包,窗口探测不携带具体的数据,只是问一下接收方,现在是否可以处理数据,能处理多少。

六. 拥塞控制

通过网络的畅通程度来控制窗口大小。

发送数据时,由于会经过很多网络设置,而网络情况是不固定的。

所以,在数据传输的过程中可能会造成阻塞和超时。

1.程序启动的时候把拥塞窗口的值调到很少,比如1,

2.如果接收到ACK表示当前窗口大小没有问题,然后就调大窗口大小

3.到达阈值之前以指数形式增大,到达阈值之后,以1为步长进行增大

4.当增大到一定程序发生丢包的情况,就证明网络阻塞了,这时就把窗口大小重新调用1,同时重置新的阈值=当前窗口大小的二分之一

拥塞窗口大小与ACK应答中的窗口大小共同决定发送的滑动窗口大小,哪个小用哪个。

七. 延迟应答

TCP在应答时,并不是每收到一个请求应答一次,而是每隔几个应答一次

及时应答的时候,窗口大小是缓冲区剩余的空间。

延迟应答时,应用程序还要从缓冲区中取走一部分数据,这时缓冲区的剩余部分就变大了,ACK时窗口大小就可以设置更大的值,最终发送方就会按这个值去增大发送窗口。

八. 捎带应答

由于TCP是全双工,接收方也可以给发送方做一个响应操作。

当主机A发送响应数据时,如果有ACK需要返回,那么这两个报文就有可能被合并成一个,减少了通讯次数,提升了效率。

相关推荐
蜜獾云1 分钟前
设计模式之原型模式:以自己为原型,自己实现自己的对象拷贝逻辑
java·设计模式·原型模式
nhc0884 分钟前
贵州本地企业做软件定制开发,怎么选靠谱服务商?
java·微信小程序·软件开发·小程序开发
Predestination王瀞潞7 分钟前
Mapper接口与XML映射文件的绑定机制(Mapper接口的动态代理实现机制)
xml·java·mybatis
h7ml10 分钟前
企业微信API接口的数据一致性保障:Java Seata分布式事务在跨系统审批流程中的应用
java·分布式·企业微信
I_LPL10 分钟前
day50 代码随想录算法训练营 图论专题3
java·算法·深度优先·图论·求职面试
维齐洛波奇特利(male)10 分钟前
IDEA 实例类多开bug:勾选后还是只能运行一个类
java·bug·intellij-idea
蜜獾云10 分钟前
设计模式之简单工厂模式(4):创建对象时不会暴露创建逻辑
java·设计模式·简单工厂模式
滴滴答滴答答11 分钟前
机考刷题之 7 LeetCode 240 搜索二位矩阵Ⅱ
java·算法·leetcode
MX_935912 分钟前
Spring的xml方式声明式事务控制
xml·java·后端·spring
进击的荆棘14 分钟前
优选算法——模拟
java·开发语言·算法·模拟