[QUIC] Receiving Stream States

Receiving Stream States

bash 复制代码
          o
          | Recv STREAM / STREAM_DATA_BLOCKED / RESET_STREAM
          | Create Bidirectional Stream (Sending)
          | Recv MAX_STREAM_DATA / STOP_SENDING (Bidirectional)
          | Create Higher-Numbered Stream
          v
      +-------+
      | Recv  | Recv RESET_STREAM
      |       |-----------------------.
      +-------+                       |
          |                           |
          | Recv STREAM + FIN         |
          v                           |
      +-------+                       |
      | Size  | Recv RESET_STREAM     |
      | Known |---------------------->|
      +-------+                       |
          |                           |
          | Recv All Data             |
          v                           v
      +-------+ Recv RESET_STREAM +-------+
      | Data  |--- (optional) --->| Reset |
      | Recvd |  Recv All Data    | Recvd |
      +-------+<-- (optional) ----+-------+
          |                           |
          | App Read All Data         | App Read Reset
          v                           v
      +-------+                   +-------+
      | Data  |                   | Reset |
      | Read  |                   | Read  |
      +-------+                   +-------+

States for Receiving Parts of Streams


Recv


这是流接收端的初始状态。

当我们从一个对方作为创建者的流上接收到 STREAM, STREAM_DATA_BLOCKED, 或者 RESET_STREAM 时, 我们便处于 Recv 状态了。

对于一个对方作为创建者的双向流(bidirectional streams ), 在接收到 MAX_STREAM_DATA 或者 STOP_SENDING 之后, 便进入 Recv 状态.

当处于 Recv 状态时, 可以接收对方发送的 STREAMSTREAM_DATA_BLOCKED 帧。 接收到的数据可能是乱序的,接收方需要先将数据缓存起来,直到足以恢复出正确的数据顺序之后,再按循序递交给上层应用程序。

当数据被成功的递交给上层应用程序之后, 内部的缓存中便有了更多的空间以容纳更多的数据,此时可以发送 MAX_STREAM_DATA 给发送方,以允许它发送更多的数据。


Size Known


当接收到带有 FIN标志的 STREAM帧之后,接收方便知道了最终的数据大小,此时进入 Size Known`` 状态。

处于当前状态的接收方, 不需要再发送 MAX_STREAM_DATA, 它只需要继续接收对方重传的数据即可。


Data Recvd


当成功的从当前流上面接收到了所有数据时, 接收方进入 Data Recvd 状态。

处于这个状态之后, 可以忽略之后接收到的所有 STREAMSTREAM_DATA_BLOCKED 帧。


Data Read


当进入 Data Recvd 状态,流会一直在这个状态直到将所有缓存的数据递交给了上层应用程序。之后, 它的状态变为 Data Read 状态。

这是一个最终状态(a terminal state).


Reset Recvd


当流处于 Recv, Size Known 或者 Data Recvd 状态时, 收到来自对方的 RESET_STREAM 帧时, 它就进入了 Reset Recvd 状态.

当收到 RESET_STREAM 之后, 接收方可以自由选择如何处理已经接收到的数据和后续到达的数据。


Reset Read


当接收方将收到RESET_STREAM 帧这一事件通知给上层应用程序之后, 这个流便进入 Reset Read 状态。

这是一个最终状态(a terminal state).

相关推荐
诗句藏于尽头4 小时前
完成ssl不安全警告
网络协议·安全·ssl
会飞的鱼先生7 小时前
Node.js-http模块
网络协议·http·node.js
lzb_kkk7 小时前
【C++】C++四种类型转换操作符详解
开发语言·c++·windows·1024程序员节
snoopyfly~8 小时前
Ubuntu 24.04 LTS 服务器配置:安装 JDK、Nginx、Redis。
java·服务器·ubuntu
Me4神秘9 小时前
Linux国产与国外进度对垒
linux·服务器·安全
Me4神秘10 小时前
电信、移动、联通、广电跨运营商网速慢原因
网络
-qOVOp-10 小时前
408第三季part2 - 计算机网络 - ip分布首部格式与分片
网络协议·tcp/ip·计算机网络
数通Dinner11 小时前
RSTP 拓扑收敛机制
网络·网络协议·tcp/ip·算法·信息与通信
牛奶咖啡1312 小时前
Linux系统的常用操作命令——文件远程传输、文件编辑、软件安装的四种方式
运维·服务器·软件安装·linux云计算·scp文件远程传输·vi文件编辑·设置yum的阿里云源
weixin_4373982112 小时前
转Go学习笔记(2)进阶
服务器·笔记·后端·学习·架构·golang