皮皮网
皮皮网
网贷源码分享

【冬至快乐源码】【外贸商店源码】【semantic源码下载】grpcjava源码

时间:2025-01-23 21:17:37 分类:知识 编辑:衡力溯源码
1.gRPC 流量控制详解
2.Java教程:dubbo源码解析-网络通信
3.java版gRPC实战之六:客户端动态获取服务端地址
4.Windows平台C++ 使用VS2015 编译gRPC(总结)
5.gRPC入坑记

grpcjava源码

gRPC 流量控制详解

       gRPC 流量控制详解

       流量控制,源码冬至快乐源码 一般来说指的是在网络传输中, 发送者主动限制自身发送数据的速率或发送的数据量, 以适应接收者处理数据的速度. 当接收者的处理速度较慢时, 来不及处理的数据会被存放在内存中, 而当内存中的数据缓存区被填满之后, 新收到的数据就会被扔掉, 导致发送者不得不重新发送, 就会造成网络带宽的浪费.

       流量控制是一个网络组件的基本功能, 我们熟知的 TCP 协议就规定了流量控制算法. gRPC 建立在 TCP 之上, 也依赖于 HTTP/2 WindowUpdate Frame 实现了自己在应用层的流量控制.

       在 gRPC 中, 流量控制体现在三个维度:

       采样流量控制: gRCP 接收者检测一段时间内收到的数据量, 从而推测出 on-wire 的数据量, 并指导发送者调整流量控制窗口.

       Connection level 流量控制: 发送者在初始化时被分配一个 quota (额度), quota 随数据发送减少, 并在收到接收者的反馈之后增加. 发送者在耗尽 quota 之后不能再发送数据.

       Stream level 流量控制: 和 connection level 的流量控制类似, 只不过 connection level 管理的是一个发送者和一个接收者之间的全部流量, 而 stream level 管理的是 connection 中诸多 stream 中的一个.

       在本篇剩余的部分中, 我们将结合代码一起来看看这三种流量控制的实现原理和实现细节.

       本篇中的源代码均来自 blogs.com/fhy/p/.html

        (本文完)

本文地址:http://8o.net.cn/html/04d153698459.html

copyright © 2016 powered by 皮皮网   sitemap