Netty 学习三

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的组件概念及架构体系
`

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值