Netty是一个基于NIO的一步网络通信框架,性能高,封装了原生NIO编码的复杂度,开发者可以直接使用Netty来开发高效率的各种网络服务器,并且编码简单。
Tomcat是一个Web服务器,是一个Servlet容器,基本上Tomcat内部只会运行Servlet程序,并处理HTTP请求,而Netty封装的是底层IO模型,关注的是网络数据传输,而不是关系具体的协议,可定制性更高。
Netty特点:
1、异步、NIO的网络通信框架
2、高性能
3、高扩展、高定制性
4、易用性
Netty线程模型:
Netty同时支持Reactor单线程模型、Reactor多线程模型和Reactor主从线程模型,用户可根据启动参数配置在三种模型之间切换。
服务端启动时,通常会创建两个NioEventLoopGroup实例,对应了两个独立的Reactor线程池,bossGroup负责处理客户端的连接请求,workerGroup负责处理I/O相关的操作,执行系统Task、定时任务Task等。用户可根据服务端引导类ServerBootStrap配置参数选择Reactor线程模型,进而最大限度地满足用户的定制化需求。
Netty高性能体现:
1、NIO模型,用最少的资源做更多的事情。
2、内存零拷贝,尽量建设不必要的内存拷贝,实现了更高效率的传输。
3、内存池设计,申请的内存可以重用,主要指直接内存。内部实现是用一颗二叉查找树管理内存分配情况。
4、串行化处理读写,避免使用锁带来的性能开销。即消息的处理尽可能再同一个线程内完成,期间不进行线程切换,这样就避免了多线程竞争和同步锁。表面上看,串行化设计似乎CPU利用率不高,并发程度不够。但是,通过调整NIO线程池的线程参数,可以同时启动多个串行化的线程并行运行,这种局部无锁化的串行线程设计相比一个队里多个工作线程模型性能更优。
5、高性能序列化协议:支持protobuf等高性能序列化协议。
6、高效并发编程的体现:volatile的大量、正确使用;CAS和原子类的广泛使用;线程安全容器的使用;通过读写锁提升并发性能。