龙空技术网

Netty的高性能表现在哪些方面?

小彭思考 135

前言:

眼前各位老铁们对“netty高性能体现在哪些方面”大体比较注重,我们都想要知道一些“netty高性能体现在哪些方面”的相关知识。那么小编同时在网上收集了一些关于“netty高性能体现在哪些方面””的相关文章,希望小伙伴们能喜欢,看官们快快来学习一下吧!

(1) IO线程模型 :同步非阻塞,用最少的资源做更多的事情,即IO多路复用。

(2) 内存零拷贝 :尽量减少不必要的内存拷贝,实现了更高效率的传输。

(3) 内存池设计 :申请的内存可以重用,主要指直接内存。内部实现是用一颗二叉查找树管理内存分配情况。

(4) 串行化处理读写 :避免使用锁带来的性能开销。即消息的处理尽可能再同一个线程内完成,期间不进行线程切换,这样就避免了多线程竞争和同步锁。表面上看,串行化设计似乎CPU利用率不高,并发程度不够。但是,通过调整NIO线程池的线程参数,可以同时启动多个串行化的线程并行运行,这种局部无锁化的串行线程设计相比一个队里-多个工作线程模型性能更优。

(5) 高性能序列化协议 :支持protobuf等高性能序列化协议。

(6) 高效并发编程的体现 :volatile的大量、正确使用;CAS和原子类的广泛使用;线程安全容器的使用;通过读写锁提升并发性能。

标签: #netty高性能体现在哪些方面