grpc-go 代码阅读笔记(二):流量控制

流量控制( Flow Control )

流量控制,是为了能更好更有效率的利用网络带宽

因为现实需求的复杂性,导致每个网络库根据自身侧重要解决的问题,都会有独特的流量控制算法

比如 TCP 有用于流量控制的 RTT 算法、滑动窗口拥塞窗口以及相关配套的重传机制

而 KCP 为了让数据包更快的到达对端,相关处理与 TCP 就不尽相同

它是允许滑动窗口中有镂空的(用于快速重传);并允许关闭拥塞窗口; RTT 算法也不一样;重传算法也更丰富

还有不少网络库,如谷歌的 QUIC ,BBR 算法等,都是为了解决 TCP 流量控制算法在现代网络应用中暴露出来的缺陷

本文介绍 gRPC-go 中的流量控制相关算法与源码

gRPC-go 的流量控制

gRPC-go 在 TCP 连接之上,使用流实现多路复用会引入一些冲突,这导致有阻塞的流

gRPC-go 的流量控制确保相同连接上的流不会破坏性的相互干扰

gRPC-go 整个连接与独立的流,都可以使用流量控制

它通过使用 http/2 的 WINDOW_UPDATE 帧来提供流量控制

gRPC-go 流量控制相关算法

1. 流控窗口算法

有别与 TCP 的滑动窗口, gRPC-go 是在 TCP 连接之上的,TCP 已经保证了数据传递的可靠性

因此 gRPC-go 的流控窗口,只需要维护大小变化。

你可能感兴趣的:(源代码分析,gRPC,gRPC-go,流量控制,源代码分析,网络库算法)