当前位置:首页 > 科技  > 软件

Netty 编程看上去懵懵的...

来源: 责编: 时间:2024-03-26 17:38:08 249观看
导读前言上篇文章《听说96.5%的程序员都没用过Netty》主要涵盖了 Netty 的入门知识,包括 Netty 的发展历程、核心功能与组件,并且通过实例演示了如何使用 Netty 构建一个 HTTP 服务器。由于 Netty 的抽象程度较高,因此理解起

前言

上篇文章《听说96.5%的程序员都没用过Netty》主要涵盖了 Netty 的入门知识,包括 Netty 的发展历程、核心功能与组件,并且通过实例演示了如何使用 Netty 构建一个 HTTP 服务器。由于 Netty 的抽象程度较高,因此理解起来可能会比较复杂,所以本文通过对比 Java NIO API 和 Netty 的示例代码,并结合Netty源码进行深入剖析,从而更好的理解Netty的工作原理。pQn28资讯网——每日最新资讯28at.com

Java NIO 网络编程流程

首先,我们知道 Netty 是基于 Java NIO API 封装扩展的一个网络编程框架,所以二者的网络编程工作流程是大差不差的。pQn28资讯网——每日最新资讯28at.com

(所以在深入了解Netty之前,建议先对Java NIO有一定的了解)pQn28资讯网——每日最新资讯28at.com

下图是基于Java NIO API进行网络编程时的工作流程。涉及到的Selector、Channel、Buffer这几个组件,《Java NIO是New IO还是Non-blocking IO》中有详细说明。pQn28资讯网——每日最新资讯28at.com

Java NIO 工作原理Java NIO 工作原理pQn28资讯网——每日最新资讯28at.com

Netty 编码 VS  Java NIO API 编码

Netty 同样会用到这些核心组件,只不过再一次抽象封装后,不能直观的看到这些组件。pQn28资讯网——每日最新资讯28at.com

先看下基于Java NIO API编程是怎么编写代码的。pQn28资讯网——每日最新资讯28at.com

Java NIO代码示例Java NIO代码示例pQn28资讯网——每日最新资讯28at.com

可以看到, ServerSocketChannel 注册到 Selector 并监听连接事件,当 Selector 接收到连接的客户端 Channel 后,又监听 Channel 的读写事件,那么下次 Selector 就会接收到客户端的读写事件并进行处理。pQn28资讯网——每日最新资讯28at.com

再看一下基于Netty构建的HTTP服务器示例。pQn28资讯网——每日最新资讯28at.com

Netty 编程Netty 编程pQn28资讯网——每日最新资讯28at.com

能看到的就只有一个对客户端读请求处理的 channelRead0 函数,Selector、ServerSocketChannel这些都没看到。pQn28资讯网——每日最新资讯28at.com

那么 ServerSocketChannel 、Selector 在哪里?事件是什么时候注册的?我们扒开裤子看个究竟。pQn28资讯网——每日最新资讯28at.com

Netty 对 Java NIO API 的封装

接下来,看一下Netty是怎么对Java NIO API进行封装的。pQn28资讯网——每日最新资讯28at.com

ServerSocketChannel 在 Netty 中的体现

关于 ServerSocketChannel 的创建,直接找绑定端口的方法,如下图pQn28资讯网——每日最新资讯28at.com

图片图片pQn28资讯网——每日最新资讯28at.com

在  NioServerSocketChannel 类中可以看到 newChannel() 函数创建了 ServerSocketChannel 。pQn28资讯网——每日最新资讯28at.com

Selector 在 Netty 中的体现

看了上文《听说96.5%的程序员都没用过Netty》,可以知道 EventLoop 负责处理各种事件,所以可以盲猜一下,Selector 应该是在 NioEventLoopGroup 中创建的pQn28资讯网——每日最新资讯28at.com

图片图片pQn28资讯网——每日最新资讯28at.com

果不其然,在 NioEventLoopGroup 的构造方法中调用 JDK 的 SelectorProvider 创建了Selector,也就是 Java NIO 的代码。pQn28资讯网——每日最新资讯28at.com

事件注册在 Netty 中的体现

ServerSocketChannel 在创建后为其分配了一个 EventLoop 并开启新的线程(这也是Netty 多线程异步的体现),最终在 doRegister() 调用了JDK 的接口注册了Selector 并监听了事件,看见 selectionKey 应该什么都清楚了吧。pQn28资讯网——每日最新资讯28at.com

图片图片pQn28资讯网——每日最新资讯28at.com

事件处理在 Netty 中的体现

既然 ServerSocketChannel 注册了Selector 并监听了事件,那接下来就是 EventLoop  对事件的处理了。直接看 NioEventLoop 中的代码,因为他是通过新的线程启动的,所以直接看 run()pQn28资讯网——每日最新资讯28at.com

图片图片pQn28资讯网——每日最新资讯28at.com

processSelectedKeysPlain() 中的代码熟悉吧,Selector 监听到了某个事件进行处理。下面是对读事件的处理pQn28资讯网——每日最新资讯28at.com

图片图片pQn28资讯网——每日最新资讯28at.com

图中 ChannelPipeline 采用了责任链模式,是对事件的处理通道,会对声明时的ChannelPipeline依次执行,也就是图[Netty 编程]中的p.addlast。pQn28资讯网——每日最新资讯28at.com

Netty 网络编程流程

最后,通过一张图梳理下 Netty 的工作流程,并体现和 Java NIO API的关系。pQn28资讯网——每日最新资讯28at.com

图片图片pQn28资讯网——每日最新资讯28at.com

总结

在接触 Netty 的之前一定要先掌握 Java NIO,不然云里雾里的。pQn28资讯网——每日最新资讯28at.com

本文只是介绍了 Java NIO 在 Netty 中的体现、Netty 对 Java NIO 的封装,让大家更方便的理解 Netty,并不涉及 Netty 的高效、强大的设计之处,下文将会对此进行介绍。pQn28资讯网——每日最新资讯28at.com

pQn28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-79445-0.htmlNetty 编程看上去懵懵的...

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 大模型应用的十种架构模式

下一篇: 使用.NET 8 Web API和Entity Framework实现CRUD操作

标签:
  • 热门焦点
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 三分钟白话RocketMQ系列—— 如何发送消息

    我们知道RocketMQ主要分为消息 生产、存储(消息堆积)、消费 三大块领域。那接下来,我们白话一下,RocketMQ是如何发送消息的,揭秘消息生产全过程。注意,如果白话中不小心提到相关代
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 网红炒股不为了赚钱,那就是耍流氓!

    来源:首席商业评论6月26日高调宣布入市,网络名嘴大v胡锡进居然进军了股市。在一次财经媒体峰会上,几个财经圈媒体大佬就“胡锡进炒股是否知道认真报道”展开讨论。有
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • 三星电子Q2营收60万亿韩元 存储业务营收同比仍下滑超过50%

    7月27日消息,据外媒报道,从三星电子所发布的财报来看,他们主要利润来源的存储芯片业务在今年二季度仍不乐观,营收同比仍在大幅下滑,所在的设备解决方案
  • AMD的AI芯片转单给三星可能性不大 与台积电已合作至2nm制程

    据 DIGITIMES 消息,英伟达 AI GPU 出货逐季飙升,接下来 AMD MI 300 系列将在第 4 季底量产。而半导体业内人士表示,近日传出 AMD 的 AI 芯片将转单给
  • OPPO K11采用全方位护眼屏:三大护眼能力减轻视觉疲劳

    日前OPPO官方宣布,全新的OPPO K11将于7月25日正式发布,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼IMX890主摄,堪称是2000档位影像表
Top