千家信息网

Netty主要的结构和类

发表于:2024-12-01 作者:千家信息网编辑
千家信息网最后更新 2024年12月01日,本篇内容介绍了"Netty主要的结构和类"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Netty在N
千家信息网最后更新 2024年12月01日Netty主要的结构和类

本篇内容介绍了"Netty主要的结构和类"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

Netty

在Netty内部主要是两个线程池(NioEventLoopGroup). 一个负责接收客户端请求, 一个负责处理IO.
当NioServerSocketChannel接收到请求后, 会将请求放入与之关联的Pipeline中, Pipeline中有很多ChannelHandlerContext, 有一个ChannelHandlerContext会将请求封装成Netty的NioSocketChannel, 最后会注册到另一个NioEventLoopGroup中的NioEventLoop上.

接收请求

基本上一个服务器只有一个NioServerSocketChannel, 并注册在NioEventLoop上. 通过一个无限循环监听客户端请求(ACCEPT). 当有多个客户端请求时, 默认情况一次读取16个客户端(某些版本是这么实现的).

处理IO

当NioSocketChannel与唯一的NioEventLoop关联后, NioEventLoop便会通过无限循环监听这个Channel的读写请求. 当接收到读请求后, 通过Unsafe读取到数据后, 会继续'传给'Pipeline, 由Pipeline中的ChannelHandlerContext继续处理, 而ChannelHandlerContext是由我们自己实现的业务, 只是我们把这些ChannelHandlerContext添加到Pipeline中而已.

"Netty主要的结构和类"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

0