Netty 学习三

本文详细介绍了Netty的核心组件,包括Channel的多种实现、EventLoop的线程与事件处理机制、ChannelFuture在异步操作中的角色、ChannelHandler和ChannelPipeline的数据处理流程,以及编码器和解码器在数据转换中的作用。通过引导部分,展示了如何基于ServerBootstrap和BootStrap进行服务端和客户端的初始化。了解这些组件有助于深入理解Netty的架构和工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Netty的组件



提示:以下是本篇文章正文内容,下面案例可供参考

一、组件介绍

1.Channel

提供基本的I/O操作(bind()、connect()、read()、write()),Netty的Channel降低了Socket的复杂性。
Channel的实现有:

  1. EmbeddedChannel
  2. LocalServerChannel
  3. NioDatagramChannel
  4. NioSctpChannel
  5. NioSocketChannel

2.EventLoop

用于处理连接的生命周期中所发生的事件。Channel、EventLoop、Thread、EventLoopGroup间的关系:

  1. 一个EventLoopGroup包含一个或多个EventLoop
  2. 一个EventLoop在它的生命周期只和一个Thread绑定
  3. 所有有EventLoop处理的I/O事件都将在它专有的Thread上被处理
  4. 一个Channel在一个生命周期只注册于一个EventLoop
  5. 一个EventLoop可能会分配不只一个Channel

3.ChnnelFuture

由于Netty是异步的,一个操作可能不会立即返回,所以提供ChannelFuture的接口通过注册ChannelFutureListener的方式通知某个操作完成(不管这个操作是否成功)

4.ChannelHandler和ChannelPipeline

  • ChannelHandler充当了所有处理入站和出站数据的应用程序逻辑容器,通常数据会流经多个处理器。
  • ChannelPipeline为ChannelHandler链提供了容器,ChannelHandler安装到ChannelPipeline的流程是:
    1.ChannelInitializer实现被注册到ServerBootstrap或BootStrap中
    2.ChannelInitializer.initChannel()方法调用时,在ChannelPipeline中安装ChannelHandler
    3.ChannelInitializer将自己从ChannelPipeline中被移除

5.编码器和解码器

Netty接收和发送消息时,数据会发生转换入站消息会解码,从字节码转换为另一种格式,通常是java对象,出站消息会编码,编码为字节码。

6.引导

  • 基于服务端的引导为ServerBootStrap,绑定到一个端口,监听连接
  • 基于客户端的引导BootStrap连接到远程端点

总结

了解Netty的组件概念及架构体系
`

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值