大家好,我是老三,之前里,我们讨论了Java的三种IO模型,提到了网络通信框架Netty,它简化和优化了NIO的使用,这期,我们正式开始走近Netty。
为什么要用Netty?首先当然是NIO的使用,本身比较复杂,而且还存在一些问题。
(资料图片仅供参考)
除此之外,如果在项目的开发中,要实现稳定的网络通信,就得考虑网络的闪断、客户端的重复接入、客户端的安全认证、消息的编解码、半包读写……
所以,巧了,恰好有这么一个成熟稳定、性能强大、开箱即用的网络框架摆在我们面前,相比较Java NIO,Netty更加出色:
易用性: Netty 在 NIO 基础上进行了更高层次的封装,屏蔽了 NIO 的复杂性,大大降低了开发难度;Netty 提供了很多开箱即用的工具,例如常用的行解码器、长度域解码器等,不需要自己再实现。稳定性: Netty 更加可靠稳定,修复和完善了 JDK NIO 较多已知问题,例如臭名昭著的 select 空转导致 CPU 消耗 100%,TCP 断线重连,keep-alive 检测等问题。可扩展性: Netty 的的可扩展性做的非常好,比如支持可定制化的线程模型。我们有什么理由拒绝这么一款优秀的网络通信框架呢?代码怎么写不是写喽!
初识Netty什么是Netty?Netty官方是这么定义Netty的:
Netty 是一个异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。
组成图-来源官方
Netty是一个开源的、单线程模型的 Java 网络编程框架。Netty基于 NIO ,被广泛应用于各种网络应用程序开发。Netty支持多种协议,包括但不限于 HTTP、WebSocket、TCP、UDP 和 SSL/TLS 协议等。Netty 是非阻塞的,事件驱动的框架。Netty具有高性能、可扩展和易于使用的优点。Netty的现状?Netty 由 JBoss 社区开发维护的,它的社区相对比较活跃:
https://github.com/netty/netty:Github已经收获31.2K星标https://netty.io/:官方网站,提供了比较完整的文档官方目前最新的版本是5.x,,但是很不幸,已经被社区放弃开发维护,属于废弃版本,最新的稳定版本是4.x 。
一般使用,推荐4.x,Netty 4.x对3.x不做兼容,我们后续的学习也基于Netty 4.x版本。
谁在用Netty?作为最流行的网络通信框架,大量的公司选择它作为底层网络通信框架,包括不限于:
使用Netty的公司
我们可能自己没有直接用过Netty,但其实熟悉的很多开源中间件,都用到了Netty,比如:
服务治理:Apache Dubbo、gRPC。大数据:Hbase、Spark、Flink、Storm。搜索引擎:Elasticsearch。消息队列:RocketMQ、ActiveMQ。用到Netty的优秀产品非常多,大家感兴趣可以看看:https://netty.io/wiki/related-projects.html。
从"Hello World"开始气氛衬托到这,不写个Demo也过不去,还是从"Hello World"开始,我们领略一下Netty的风采。
创建一个Maven项目:这个就不用多说了吧创建Maven项目
导入依赖:我们直接用4.x最新的版本
编写代码:那么我们就开始编写这个Demo的服务器和客户端相关代码NettyServer:基于Netty的客户端
Date: 2023/5/14 10:29 Author: fighter3 Description: Netty服务端Demo/** *
NettyServerHandler:服务器的消息处理器,用于处理各种事件
Date: 2023/5/14 10:30 Author: fighter3 Description: Netty服务器消息处理器/** *
NettyClient:使用Netty的客户端,通过ip和端口连接服务端
Date: 2023/5/14 10:32 Author: fighter3 Description: Netty客户端Demo/** *
NettyClientHandler:Netty客户端处理器,用于处各种事件
Date: 2023/5/14 10:33 Author: fighter3 Description: Netty客户端处理器/** *
运行一下:先启动NettyServer,再启动NettyClient,看下运行结果
============Netty服务器启动...=============Netty服务器监听端口:8888客户端发来的消息:大佬,带带我!
===========Netty客户端连接服务端=========服务端发来的消息:你好,靓仔!
好了,一个简单的Netty入门Demo就写完了,Netty是一个双工通信的网络框架,可以看到,服务端和客户端,流程基本上一致,主要包括这么几个步骤:
创建事件循环组和相关对象,用于监听和处理网络事件;配置 Netty 服务器或客户端的启动参数,包括线程组、通道类型、TCP 参数等;给服务器或客户端的 ChannelPipeline 添加各种 ChannelHandler,用于处理不同的网络事件;绑定端口启动服务器或连接服务器;等待服务器或客户端连接关闭,释放相关资源。服务器&客户端初始化启动流程
虽然这个Demo比较简单,但其实已经用到了Netty里几个比较关键的组件:
ByteBuf:Netty 的字节容器,类似于 Java 的 ByteBuffer,但是提供了更加强大、简便且安全的 API,用于在网络中传递二进制数据;EventLoopGroup:Netty 的事件循环组,用于管理和调度连接到服务器或者从服务器连接出去的所有 Channel 上的事件循环;ServerBootstrap:Netty 的服务器启动类,用于启动和配置一个 TCP/IP 服务器;Bootstrap:Netty 的客户端启动类,用于启动和配置一个 TCP/IP 客户端;Channel:Netty 的核心概念,用于表示一个通信通道,可以读取和写入数据;ChannelPipeline:Netty 的 Channel 处理器,用于在传入的数据上执行一组 ChannelHandler;ChannelHandler:Netty 的核心组件,用于处理各种通信事件,例如读取数据、写数据、建立连接等;Netty的重要组件
后续,我们还会和这些组件打更多的交道。
好了,那么这期内容就到这了,这期里我们初步了解了Netty,包括什么是Netty、Netty现状、Netty的应用,还写了一个简单的Demo。下一期,我们继续深入了解Netty,敬请期待。
参考:[1].https://netty.io/
[2].《Netty权威指南》
[3]. 《Netty核心原理剖析与RPC实践》
标签:
大家好,我是老三,之前里,我们讨论了Java的三种IO模型,提到了网...
格隆汇5月23日丨智云健康发布公告,董事会获公司若干高级管理层成员...
在市场预期范围内,LPR报价已连续第9个月“按兵不动”。5月22日,据...
摩根大通商业银行业务主管DougPetno:摩根大通商业地产贷款组合中办...
湖南日报5月22日讯(全媒体记者奉永成)“听说你们的金牌‘店小二’...
老山界,在地图上名为越城岭,又称瑶山,是五岭之一,越城岭的中段...
5月22日,宠物生活方式DTC品牌PAWKA泡咔(以下称“泡咔”)宣布,已...
“赛前已经感觉到对手球路会让我有些不舒服,毕竟他是从中国过去的...
有过买卖房子经历的人,或许都绕不开房产中介。在房地产行业调控的...
【900亿隔膜巨头起诉事关这家比亚迪参投IPO公司】5月22日,市值超90...
为进一步做好道路交通安全和运输执法领域突出问题专项整治社会面宣...
5月19日,关岭自治县举行2023年全国老年人太极拳健身推广展示大联动...
今天来聊聊关于福建省福州晋安区邮编,福州晋安区邮编的文章,现在...
恒生前海恒悦纯债增聘基金经理吕程
今天来聊聊关于三国群英传mod合集电脑版,三国群英传7哪个mod好玩的...
财政部下达100亿元补助资金预算支持改善普通高中学校办学条件-郑州...
索辰科技近期披露投资者关系活动记录表显示,公司目前已形成流体、...
【搭子在年轻人中流行】“上班随时在线,下班立即失联。”你以为这...
为进一步落实就业服务保障工作,切实帮助有意愿就业的劳动者和就业...
今天来聊聊关于雪花影院电影在线观看高清,97dyycom的文章,现在就...
Mysteel:机械原材料周报(5 15-5 19)
独秀故里,“蓝”以忘“怀”。5月20日,第六届中国怀宁蓝莓文化旅游...
界面新闻记者|王婷婷房地产行业的代建风浪正如潮涌至。两年前开发商...
佛山2023年5月19日 美通社 --5月18日,2023年中国家用电器技术大...
【权威发布·在自治区例行新闻发布会上】天山网-新疆日报讯(记者王...
韩方呼吁中方推迟对韩产锂电池执行强制性产品认证认证(观察着网讯)...
5月19日,硅烷科技(838402)融资买入1 1万元,融资偿还5 42万元...
黑色四叶草漫画迎来了第359话的更新,在这一话中,继续来到了卢修斯...
同花顺F10数据显示,2023年5月22日登康口腔(001328)新增“深股通...
今天来聊聊关于的诱惑游戏,邪恶性游戏之致命诱惑的文章,现在就为...