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主要的结构和类”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


本文标题:Netty主要的结构和类
网站路径:http://myzitong.com/article/gsijdd.html