我自横刀向天笑,去留肝胆两昆仑。这篇文章主要讲述Netty 简介《Netty In Action》 #yyds干货盘点#相关的知识,希望能为你提供帮助。
@[TOC](第2章 Netty 简介)
前言参考资料:
- 《Netty In Action》;
1. Netty 简介
- Netty 是一个异步的、基于事件驱动的网络应用框架;
- Netty 主要针对在 TCP 协议下,面向 Clients 端的高并发应用,或者 Peer-to-Peer 场景下的大量数据持续传输的应用;
- Netty 本质是一个 NIO 框架,适用于服务器通讯相关的多种应用场景;
- Netty 的特性总结:
分类 Netty 的特性 设计 统一的 API,支持多种传输种类,阻塞和非阻塞的;无连接数据报套接字支持;链接逻辑组件支持复用 易于使用 JDK 1.8+ 的依赖;文档资料多 性能 比 java 核心 API 更高的吞吐量以及更低的延迟 健壮性 在慢速、快速或超载的连接下正常运行; 安全性 完整的 SSL/TLS 以及 StartTLS 支持 社区驱动 发布快速且频繁 - 异步和可伸缩性间的关系:
- 异步允许我们以任意顺序响应在任意时间点产生的事件;
- 可伸缩性要求我们在需要处理的工作不断增长时,处理它的能力也要扩大;
- 非阻塞网络调用允许我们不必等待一个操作的完成;
- 完全异步 IO 在完成时,会直接或在稍后某个时间点通知用户;
- 选择器使得我们能够通过较少的线程便可监视许多连接上的事件;
- Channel 是 Java NIO 的一个基本构造;
- 它代表一个到实体的开放连接;
- Channel 可以是传入(入站)或传出(出站)数据的载体;它可以被打开或关闭,连接或断开连接;
- 回调指:一个指向已经被提供给另外一个方法的方法的引用;
- Netty 在内部使用回调处理事件:当一个回调被触发时,相关事件可以被一个
interface-ChannelHandler
是实现处理;
- Future 提供另一种在操作完成时通知应用程序的方法;
- Netty 提供自己的实现——ChannelFuture,用于在执行异步操作时使用;
- 监听器的回调方法
operationComplete()
,将会在对应的操作完成是被调用; - 每个 Netty 的出站 IO 操作都会返回一个 ChannelFuture;
- Netty 使用不同的事件来通知我们状态的改变或操作的状态。这使得我们能够基于发生的事件来触发适当的动作;
- 由入站数据或相关状态更改而触发的事件包括:
- 连接已被激活或者连接失败;
- 数据读取;
- 用户事件;
- 错误事件;
- 出站事件是在未来会触发的某个动作的结果,这些动作有:
- 打开或关闭到远程节点的连接;
- 将数据写到或冲刷到套接字;
文章图片
2.5 Netty 的设计
- Netty 的异步编程模型建立在 Future 和回调之上,而将事件派发到 ChannelHandler 的方法发生在更深的层次上;
- 拦截操作以及高速地转换入站数据和出站数据,都只需要提供回调或者利用操作所返回的 Future;
- Netty 通过触发事件将 Selector 从应用程序中抽象出来,消除了原有将需要手动编写的派发代码;
- 在内部,Netty 会为每个 Channel 分配一个 EventLoop,用以处理所有事件;
- EventLoop 本身是一个线程驱动,其处理了一个 Channel 的所有 IO 事件,并且在该 EventLoop 的整个生命周期内不会改变;
新人制作,如有错误,欢迎指出,感激不尽!
:::
::: hljs-center
欢迎关注公众号,会分享一些更日常的东西!
:::
::: hljs-center
如需转载,请标注出处!
:::
::: hljs-center
【Netty 简介《Netty In Action》 #yyds干货盘点#】
文章图片
:::nimg.cn/693ff817a911478980ed25842e259b2b.png" width=" 50%" >
推荐阅读
- 北亚数据恢复NTFS文件系统误操作导致raid5阵列中的分区被格式化的逆向操作服务器数据恢复方法
- 肝魂一晚上总结(全网最全最细手把手教你PyQt5安装与使用??《??记得收藏??》)
- OpenHarmony移植案例(如何适配服务启动引导部件bootstrap_lite)
- 回顾2021 Github最受欢迎的前端项目,谷歌 zx 位居榜首!
- 如何编写sdk()
- 简单的JS鸿蒙小游戏——拼图(冬奥一起拼)
- #yyds干货盘点#HCIE-Security Day14(防火墙双机热备实验防火墙直路部署,上下行连接路由器)
- Redis Cluster集群工作原理+集群操作实战+数据故障切换 #yyds干货盘点#
- #私藏项目实操分享#利用鸿蒙JavaUI 框架的 WebView 加载本地冰墩墩网页