tomcat---tomcat性能优化

    一般来说,普通的公司开发服务器都是用的apache-tomcat作为生产环境,但就像我现在的公司一样,接触的项目都是并发和用户很少的。也没有对tomcat进行过优化,一般就够用的。但是一旦碰到高并发的情况下,就可能导致系统性能下降。

网上有一些性能优化的办法,我再做一下整理,方便自己以后翻阅。

tomcat优化大致一共四种,内存、线程、IO、APR下边将分别介绍:

一 :内存优化

    启动时,直接告诉JVM我需要一大块内容,这是最直接,也是最简单的办法。

    Windows 下的catalina.bat

    Linux 下的catalina.sh 如:

JAVA_OPTS='-Xms256m -Xmx512m'

    -Xms<size> JVM初始化堆的大小

    -Xmx<size> JVM堆的最大值 实际参数大小根据服务器配置或者项目具体设置

二: 线程优化

    

<Connector port="80" protocol="HTTP/1.1" maxThreads="600" 
minSpareThreads="100" maxSpareThreads="500" acceptCount="700"
connectionTimeout="20000"  />

    maxThreads="X" 表示最多同时处理X个连接

    minSpareThreads="X" 初始化时创建的线程数

    maxSpareThreads="X" 表示如果最多可以有X个线程,一旦超过X个,则会关闭不在需要的线程

    acceptCount="X" 当同时连接的人数达到maxThreads时,还可以排队,队列大小为X.超过X就不处理

三: IO 优化

    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开始支持。
    可以在server.xml中实现IO的切换

<Connector port="80" protocol="org.apache.coyote.http11.Http11NioProtocol" 
    connectionTimeout="20000" 
    URIEncoding="UTF-8" 
    useBodyEncodingForURI="true" 
    enableLookups="false" 
    redirectPort="8443" />

四:APR

    APR(Apache Portable Runtime)是一个高可移植库,它是Apache HTTP Server 2.x的核心.能更好地和其它本地web技术集成,总体上让Java更有效率作为一个高性能web服务器平台而不是简单作为后台容器。

    在产品环境中,特别是直接使用Tomcat做WEB服务器的时候,应该使用Tomcat Native来提高其性能.如果不配APR,基本上300个线程狠快就会用满,以后的请求就只好等待.但是配上APR之后,并发的线程数量明显下降,从原来的300可能会马上下降到只有几十,新的请求会毫无阻塞的进来。

    在局域网环境测,就算是400个并发,也是一瞬间就处理/传输完毕,但是在真实的Internet环境下,页面处理时间只占0.1%都不到,绝大部分时间都用来页面传输.如果不用APR,一个线程同一时间只能处理一个用户,势必会造成阻塞。所以生产环境下用apr是非常必要的。

安装Apache Tomcat Native Library,直接启动就支持apr(http://tomcat.apache.org/native-doc/)它本身是基于APR的. 具体安装方法可以参考其他博客和文章. 排除代码问题Tomcat优化到这个层次,可以应对大部分性能需求。

最后一句话"再牛B的服务器,也顶不住一个傻B的代码".优化的前提条件是良好的代码质量和设计.

 参考于https://www.cnblogs.com/zhuawang/p/5213192.html

快写完文章时候又看到一篇文章,写的很好,推荐再看一下下边文章

Tomcat 调优及 JVM 参数优化https://blog.csdn.net/ldx891113/article/details/51735171

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值