在tomcat下,有三种运行模式,分别bio,nio,apr。
1:同步阻塞IO(JAVA BIO) 同步并阻塞,服务器实现模式为一个连接一个线程(one connection one thread 想想都觉得恐怖,线程可是非常宝贵的资源),当然可以通过线程池机制改善.
2:JAVA NIO:又分为同步非阻塞IO,异步阻塞IO 与BIO最大的区别one request one thread.可以复用同一个线程处理多个connection(多路复用).
3:,异步非阻塞IO(Java NIO2又叫AIO) 主要与NIO的区别主要是操作系统的底层区别.可以做个比喻:比作快递,NIO就是网购后要自己到官网查下快递是否已经到了(可能是多次),然后自己去取快递;AIO就是快递员送货上门了(不用关注快递进度)。
BIO方式适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用中,JDK1.4以前的唯一选择,但程序直观简单易理解.
NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持.
AIO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持.
修改为NIO方式:
修改$TOMCAT_HOME/conf/server.xml
修改后,重启tomcat时,显示以下代码为正常
INFO: Starting ProtocolHandler ["http-nio-8102"]
===============================================================================
大杀器:APR
APR(Apache Portable Runtime)是一个高可移植库,它是Apache HTTP Server 2.x的核心.能更好地和其它本地web技术集成,总体上让Java更有效率作为一个高性能web服务器平台而不是简单作为后台容器.
APR是从操作系统级别来解决异步的IO问题,大幅度的提高性能
以下是APR的安装步骤:
首先安装
yum install libapr1.0-dev libssl-dev yum install apr-devel openssl-devel
下载apr: wget http://apache.opencas.org//apr/apr-1.5.2.tar.gz 下载apr-util wget http://apache.opencas.org//apr/apr-util-1.5.4.tar.gz 分别解压以上两个文件后 cd apr-1.5.2 ./configure --prefix=/usr/local/apache2/apr make && make install cd apr-util-1.5.4 ./configure --prefix=/usr/local/apache2/apr --with-apr=/usr/local/apache2/apr make && make install 在Tomcat的程序包中,在bin目录下有bin/tomcat-native.tar.gz,解开,执行: cd tomcat-native-1.1.24-src/jni/native 首先执行echo $JAVA_HOME,得出JAVA安装路径,再执行以下代码: ./configure --prefix=/usr/local/apache2/apr --with-apr=/usr/local/apache2/apr --with-java-home=/usr/java/jdk1.7.0_10 --with-ssl=yes make && make install 修改$TOMCAT_HOME/bin/catalina.sh文件,添加如下代码: CATALINA_OPTS='-Djava.library.path=/usr/local/apache2/apr/lib' 修改$TOMCAT_HOME/conf/server.xml重启tomcat,如果出现以下代码,则为正常设置为apr: Feb 24, 2016 11:49:52 PM org.apache.coyote.AbstractProtocol start INFO: Starting ProtocolHandler ["http-apr-8080"] Feb 24, 2016 11:49:52 PM org.apache.coyote.AbstractProtocol start INFO: Starting ProtocolHandler ["ajp-apr-8010"] Feb 24, 2016 11:49:52 PM org.apache.catalina.startup.Catalina start