service mesh初了解,remoting模块分析
Posted jinr
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了service mesh初了解,remoting模块分析相关的知识,希望对你有一定的参考价值。
本文是继《RocketMQ remoting模块分析》后添加的一篇,针对Netty如何实现HTTP Server进行的调研。
一句话总结:Netty 提供的 ChannelHandler,可以直接用来处理 HTTP 和 HTTPS 协议,而不必编写自定义的编解码器。
图 11-2 和图 11-3 分别展示了生产和消费 HTTP 请求和 HTTP 响应的方法。
一个 HTTP 请求/响应可能由多个数据部分组成,并且它总是以一 个 LastHttpContent 部分作为结束。FullHttpRequest 和 FullHttpResponse 消息是特 殊的子类型,分别代表了完整的请求和响应。所有类型的 HTTP 消息(FullHttpRequest、 LastHttpContent 以及代码清单 11-2 中展示的那些)都实现了 HttpObject 接口。
两种实现方式
方式一
(参考github项目)
方式二
(参考github项目1)
(参考github项目2)
在 ChannelInitializer 将 ChannelHandler 安装到 ChannelPipeline 中之后,你 便可以处理不同类型的 HttpObject 消息了。但是由于 HTTP 的请求和响应可能由许多部分组 成,因此你需要聚合它们以形成完整的消息。为了消除这项繁琐的任务,Netty 提供了一个聚合 器,它可以将多个消息部分合并为 FullHttpRequest 或者 FullHttpResponse 消息。通过 这样的方式,你将总是看到完整的消息内容。
作者:运动书生
链接:https://www.jianshu.com/p/ef5da017b125
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
以上是关于service mesh初了解,remoting模块分析的主要内容,如果未能解决你的问题,请参考以下文章