Tomcat 三种线程模式
一、bio(blocking I/O)
即阻塞式I/O操作,表示Tomcat使用的是传统的Java I/O操作(即java.io包及其子包)。是基于JAVA的HTTP/1.1连接器,Tomcat7以下版本在默认情况下是以bio模式运行的。一般而言,bio模式是三种运行模式中性能最低的一种。我们可以通过Tomcat Manager来查看服务器的当前状态。(Tomcat7或以下,在 Linux 系统中默认使用这种方式)
一个线程处理一个请求,缺点:并发量高时,线程数较多,浪费资源
二、nio(new I/O)
是Java SE 1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)。Java nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,因此nio也被看成是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能。要让Tomcat以nio模式来运行只需要在Tomcat安装目录/conf/server.xml 中将对应的中protocol的属性值改为 org.apache.coyote.http11.Http11NioProtocol即可
利用 Java 的异步请求 IO 处理,可以通过少量的线程处理大量的请求
注意: Tomcat8 以上版本在 Linux 系统中,默认使用的就是NIO模式,不需要额外修改 ,Tomcat7必须修改Connector配置来启动
undefined
三、apr(Apache Portable Runtime/Apache可移植运行时) ( 安装配置过程相对复杂)
Tomcat将以JNI的形式调用Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能。Tomcat apr也是在Tomcat上运行高并发应用的首选模式。从操作系统级别来解决异步的IO问题
undefined
zhuawang’s blog三种高级运行模式
主要注意的一点:
毕竟 APR 是 c 语言编写的,是非跨平台的,如果你追求稳定和简单的话,推荐还是默认的 NIO 模式
Tomcat启动的时候,可以通过log看到Connector使用的是哪一种运行模式:
- Starting ProtocolHandler [“http-bio-8080”]
- Starting ProtocolHandler [“http-nio-8080”]
- Starting ProtocolHandler [“http-apr-8080”]
APR 安装
APR 官网下载地址
- APR 1.6.5 is the best available version
- APR-util 1.6.1 is the best available version
- APR iconv 1.2.2 is the best available version
安装顺序
1 | # 下载APR依赖包 |
Tomcat APR模式配置
Native 解压配置
1 | [root@iZuf6iq8e7ya9v3ix71k0pZ apr-util-1.6.1]# cd /opt/install/apache-tomcat-9.0.14/bin |
NIO 和 APR 压力测试
安装压力测试 apache A/B 测试
1 | [root@iZuf6iq8e7ya9v3ix71k0pZ apache-tomcat-9.0.14]# yum install httpd-tools |
启动不同模式的 Tomcat 服务
1 | 21-Jan-2019 17:03:41.288 信息 [main] org.apache.coyote.AbstractProtocol.start 开始协议处理句柄["http-apr-8081"] |
TP99 性能指标
1 | ab -n 3000 -c 100 http://smniuhe.com:8081/xxx/list |