[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).

相关推荐
奇树谦11 分钟前
FastDDS路由可达的跨网段通信支持说明
网络
咕噜企业分发小米24 分钟前
直播云服务器安全防护有哪些最新的技术趋势?
运维·服务器·安全
空城雀30 分钟前
python精通连续剧第一集:简单计算器
服务器·前端·python
秋风未动蝉已先觉32 分钟前
CentOs服务器 systemctl执行权限授权给普通权限work用户
linux·服务器
程序员zgh37 分钟前
Linux 系统调用
linux·运维·服务器·c语言·c++·系统安全
DX_水位流量监测1 小时前
无人机测流之雷达流速仪监测技术分析
大数据·网络·人工智能·数据分析·自动化·无人机
P-ShineBeam1 小时前
八卡A100服务器坏卡引发 CUDA initialization: cudaGetDeviceCount()异常
运维·服务器·人工智能·语言模型
Xの哲學1 小时前
Linux io_uring 深度剖析: 重新定义高性能I/O的架构革命
linux·服务器·网络·算法·边缘计算
cly11 小时前
Ansible自动化(十四):Roles(角色)
服务器·自动化·ansible
Nobody__11 小时前
解决多台服务器 UID/GID 做对齐后,文件系统元数据未更新的情况
运维·服务器