Netty的高性能

Netty的高性能
比传统IO性能提高了8倍

传统RPC调用性差的原因
1 阻塞IO不具备弹性伸缩能力,高并发导致宕机
2 Java序列化编解码的性能问题
3 传统IO线程模型过多占用CPU资源
在这里插入图片描述
NioEventLoop聚合了多路复用器Selector,可以同时并发处理成百上千个客户端Channel,由于读写操作都是非阻塞的,这就可以充分提升IO线程的运行效率,避免由于频繁IO阻塞导致的线程挂起。
在这里插入图片描述
在这里插入图片描述
NIO客户端流程
在这里插入图片描述
零拷贝:
1,接收和发送ByteBuffer使用堆外直接内存进行Socket读写
2,提供了组合Buffer对象,可以聚合多个ByteBuffer对象
3,tarnsferTo直接将文件缓冲区的数据发送到目标Channel
内存池:
三个维度:
1,Pooled与Unpooled(池化与非池化)
2,Unsafe和非UnSafe(底层读写与应用程序读写)
3,Heap和Direct(堆内存与对外内存)

高效的Reactor线程模型
1.Reactor单线程模型
2.Reactor多线程模型
3.主从Reactor多线程模型

Netty的高效并发编程主要体现在如下几点:
1、volatile的大量、正确使用
2、CAS和原子类的广泛使用
3、线程安全容器的使用
4、通过读写锁提升并发性能
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值