netty 对 http2 消息的封装

本文探讨了HTTP/2中的stream和frame结构,重点介绍了Netty对HTTP/2的封装,特别是Http2Stream接口及其状态管理。同时提到了一份针对Java开发者的学习资料,包含了基础知识、进阶课程和面试准备等内容。
摘要由CSDN通过智能技术生成

DATA frameHEADERS framePRIORITY frameRST_STREAM frameSETTINGS acknowledgment frameSETTINGS framePING framePING acknowledgmentPUSH_PROMISE frameGO_AWAY frameWINDOW_UPDATE frameUnknown Frame 我们看一下 http2 中 stream 和 frame 的一个大体的结构:

在 http2 中,一个 TCP 连接,可以承载多个数据流 stream,多个 stream 中的不同 frame 可以交错发送。

每个 frame 通过 stream id 来标记其所属的 stream。

有了上面的 http2 的基本概念,我们接下来就看下 netty 对 http2 的封装了。

netty 对 http2 的封装 Http2Stream 作为一个 TCP 连接下面的最大的单位 stream,netty 中提供了接口 Http2Stream。注意,Http2Stream 是一个接口,它有两个实现类,分别是 DefaultStream 和 ConnectionStream。

Http2Stream 中有两个非常重要的属性,分别是 id 和 state。

id 前面已经介绍了,是 stream 的唯一标记。这里要注意由客户端建立的 Stream ID 必须是奇数,而由服务端建立的 Stream ID 必须是偶数。另外 Stream ID 为 0 的流有特殊的作用,它是 CONNECTION_STREAM_ID,1 表示 HTTP_UPGRADE_STREAM_ID。

state 表示 stream 的状态,具体而言,stream 有下面几个状态:

IDLE(false, false), RESERVED_LOCAL(false, false), RESERVED_REMOTE(false, false), OPEN(true, true), HALF_CLOSED_LOCAL(false, true), HALF_CLOSED_REMOTE(true, false), CLOSED(false, false);

为什么状态需要区分 local 和 remote 呢?这是因为 stream 连接的两端,所以有两端的状态。

和 stream 状态相对应的就是 http2 的生命周期了。netty 提供了 Http2LifecycleManager 来表示对 http2 生命周期的管理:

void closeStreamLocal(Http2Stream stream, ChannelFuture future);``void closeStreamRemote(Http2Stream stream, ChannelFuture future);``void closeStream(Http2Stream stream, ChannelFuture future);``ChannelFuture resetStream(ChannelHandlerContext ctx, int streamId, long errorCode, ChannelPromise promise);``ChannelFuture goAway(ChannelHandlerContext ctx, int lastStreamId, long errorCode, ByteBuf debugData, ChannelPromise promise);``void onError(ChannelHandlerContext ctx, boolean outbound, Throwable cause);

分别是关闭 stream,重置 stream,拒绝新建 stream:goAway,和处理出错状态这几种。

Http2Framestream 之后,就是真实承载 http2 消息的 Http2Frame 了。在 netty 中,Http2Frame 是一个接口,它有很多具体的实现。

Http2Frame 的直接子类包括 HTTP2GoAwayFrame、HTTPPingFrame、Http2SettingsFrame 和 HTTP2SettingsAckFrame。

其中 goAway 表示不接受新的 stream,ping 用来进行心跳检测。SETTINGS 用来修改连接或者 Stream 流的配置。

netty 中专门有一个 Http2Settings 类和其对应。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

就写到这了,也算是给这段时间的面试做一个总结,查漏补缺,祝自己好运吧,也希望正在求职或者打算跳槽的 程序员看到这个文章能有一点点帮助或收获,我就心满意足了。多思考,多问为什么。希望小伙伴们早点收到满意的offer! 越努力越幸运!

金九银十已经过了,就目前国内的面试模式来讲,在面试前积极的准备面试,复习整个 Java 知识体系将变得非常重要,可以很负责任的说一句,复习准备的是否充分,将直接影响你入职的成功率。但很多小伙伴却苦于没有合适的资料来回顾整个 Java 知识体系,或者有的小伙伴可能都不知道该从哪里开始复习。我偶然得到一份整理的资料,不论是从整个 Java 知识体系,还是从面试的角度来看,都是一份含技术量很高的资料。

三面蚂蚁核心金融部,Java开发岗(缓存+一致性哈希+分布式)

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
18634)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 23
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值