1· NIO模型,用最少的资源做更多的事情。
2.内存零拷贝,尽量减少不必要的内存拷贝,实现了更高效率的传输。
3.内存池设计,申请的内存可以重用,主要指直接内存。内部实现是用一颗二叉查找树管理内存分配情况。
4.串行化处理读写:避免使用锁带来的性能开销。即消息的处理尽可能再同一个线程内完成,期间不进行线程切换,这样就避免了多线程竞争和同步锁。表面上看,串行化设计似乎 CPU 利用率不高,并发程度不够。但是,通过调整 NIO 线程池的线程参数,可以同时启动多个串行化的线程并行运行,这种局部无锁化的串行线程设计相比一个队里﹣多个工作线程模型性能更优。
5.高性能序列化协议:支持 protobuf 等高性能序列化协议。
6.高效并发编程的体现: volatile 的大量、正确使用; CAS 和原子类的广泛使用;线程安全容器的使用;通过读写锁提升并发性能。
Netty 的高性能体现在哪些方面
最新推荐文章于 2025-04-01 18:05:11 发布