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

本文深入探讨了gRPC-go的流量控制机制,包括流控窗口算法和自适应增长策略。流量控制确保在同一连接上的多个流不会相互干扰,采用http/2的WINDOW_UPDATE帧进行管理。gRPC-go初始窗口大小为65535,当带宽充足时,窗口可自适应增长至16M。文章还提到了bdp估算和ping机制,并指出了相关代码文件供读者进一步研究。
摘要由CSDN通过智能技术生成

流量控制( 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 帧来提供流量控制

`io.grpc:protoc-gen-grpc-java:1.0.0:exe:${os.detected.classifier}` 是一个 Maven 坐标,用于使用 gRPC 的 Protocol Buffers 编译器插件来生成 gRPC 相关的 Java 代码。 这个坐标指定了以下部分: - `io.grpc` 是 Maven 组织 ID,表示该插件是由 gRPC 提供的。 - `protoc-gen-grpc-java` 是插件的名称,用于生成 gRPC 相关的 Java 代码。 - `1.0.0` 是插件的版本号,表示要使用的插件版本。 - `exe:${os.detected.classifier}` 指定了插件的文件类型和操作系统相关的后缀。 `${os.detected.classifier}` 是一个 Maven 变量,用于根据操作系统自动选择相应的插件文件。它会根据当前操作系统选择适当的文件后缀,例如在 Windows 上是 `.exe`,在 Linux 上是 `.linux-x86_64`。 通过在 Maven 项目的 `pom.xml` 文件中添加该依赖项,您可以在构建过程中自动下载并使用该插件来生成 gRPC 的 Java 代码。例如: ```xml <plugins> <plugin> <groupId>org.xolstice.maven.plugins</groupId> <artifactId>protobuf-maven-plugin</artifactId> <version>0.6.1</version> <configuration> <protocArtifact>com.google.protobuf:protoc:3.17.3:exe:${os.detected.classifier}</protocArtifact> <pluginId>grpc-java</pluginId> <pluginArtifact>io.grpc:protoc-gen-grpc-java:1.0.0:exe:${os.detected.classifier}</pluginArtifact> </configuration> <executions> <execution> <goals> <goal>compile</goal> <goal>compile-custom</goal> </goals> </execution> </executions> </plugin> </plugins> ``` 这样配置后,您可以使用 `mvn compile` 命令来自动生成 gRPC 的 Java 代码。生成的代码将位于 `target/generated-sources/protobuf` 目录下。 请确保您的 Maven 项目中已经包含了正确的依赖项,并且配置文件中的版本号与您所需的版本一致。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fananchong2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值