Netty

1.什么是Netty?


基于NIO模型的高性能网络通信框架,

是对NIO网络模型的一个封装提供了简单易用的api,我们可以利用封装好的api去快速开发一个网络程序

Netty在NIO的基础上做了一些优化 1,零拷贝机制 2.高性能无锁队列,3.内存池 等 所以Netty性能比NIO高

Netty可以支持多种通信协议 http websocket等 针对数据通信拆包黏包的一些问题Netty内置了拆包策略

2.为什么使用Netty


相比于直接使用JDK自带的NIO相关的API来说 会更加简单

特点 1.统一的API 支持多种传输类型(阻塞、非阻塞)以及epoll、poll等模型2.可以使用非常少的代码去实现多线程Reactor模型以及主从Reactor模型 3.自带编解码器 可以解决TCP粘包拆包的一个问题 4.自带的各种通信协议 5.相比于直接使用JAVA库中的NIO提供了更高的一个吞吐量以及更低的延迟 更低的资源消耗 更小的内存复制 6.安全性更好 有完整SSL/TLS的一个支持7.社区活跃度好 版本迭代稳定 经历过大的考验 (Dubbo,Zookeeper,RocketMQ这些都用到Netty)

3.Netty可以干什么


解决服务器承载更多用户同时访问的问题 传统的BIO 有个阻塞的特性 使我们在高并发场景不能支持更高的吞吐量 而基于NIO的多路复用模型 可以在阻塞方面进行优化 但是API的使用比较复杂 而Netty是基于NIO的一个封装 提供了成熟简单易用的API降低了使用成本和学习成本 本质上 Netty和NIO 扮演的角色是一样的 都是用来提升服务端的吞吐量

4.Netty里有哪些核心组件 分别有什么作用


Netty是由三部分组成 1.网络通信层2.事件调用层3.服务编排层

网络通信层

  1. Bootstrap 负责客户端启动,连接远程的Netty server

  1. ServerBootStrap 负责服务端的监听 监听指定的一个端口

  1. Channet 负责网络通信的一个载体

事件调用层

1.EventLoopGroup 本质上是一个线程池 主要负责接受IO请求并分配线程去执行处理请求

2.EventLoop 相当于线程池中一个具体线程

服务编排层

  1. ChannelPlpeline 负责处理多个Channelhandler 会将多个Channelhandler构成一个链去形成一个Pipetin

  1. Channelhandler 针对IO数据的一个处理器 数据接收后通过一个Hander进行处理

  1. ChannerHanderContext 去保存Channelhandler的一个上下文信息

5.Netty有几种线程模型


单线程单Reactor模型 多线程单Reactor 多线程多Reactor模型(主从多线程Reactor模型)

6.对Netty这些线程模型的理解


6.1 Reactor模型的组件和作用

  1. Reactor 负责将IO事件分配给对应的Handler

  1. Acceptor 处理客户端的连接请求

  1. handlers 执行业务逻辑的读写操作

6.2 单线程单Reactor模型

从连接到IO事件处理由一个线程处理

6.3 多线程单Reactor模型

所有IO操作由一个Reactor完成的 Reactor会存在性能瓶颈

高并发情况会因为Reactor的阻塞或者性能瓶颈 影响吞吐量

当线程超过负载后处理速度会变慢 导致大量客户端连接超时

超时后会进行重发 加重了线程的负载 会导致消息积压 和处理超时

6.4多线程多Reactor模型

Main Reactor 负责接收客户连接请求将请求传递到SubReactor(可配置多个 可以进行灵活的扩容和缩容)业务IO处理由SubReactor 完成 绑定对应的Hander subReactor 请求接收者会将请求的消息转发到Main Reactor来处理 Main Reactor再交给SubReactor进行分发

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

龙龙爱喝奶茶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值