zoukankan      html  css  js  c++  java
  • tomcat8优化-调整tomcat参数进行优化

    1.禁用APJ服务

      1.1 修改conf目录下的,service.xml文件

        

       1.2 查看报告

        

        可以看到,禁用AJP服务后,吞吐量有所提升;

        当然了,测试不一定准确,需要多册测试才能看出是否有所提升;

    2.设置线程池

      通过设置线程池,调整线程池相关的参数进行测试tomcat的性能

      2.1 最大线程数为500,初始为50

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true"/>

        测试结果:     

          

           吞吐量为128次/秒,性能有所提升;

      2.2 最大线程数为1000,初始为200

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="1000" minSpareThreads="200" prestartminSpareThreads="true"/>

        测试结果:

          

      2.3 最大线程数为5000,初始为1000

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="5000" minSpareThreads="1000" prestartminSpareThreads="true"/>

        测试结果:

          

           可以看到,虽然最大线程已经设置到5000,但是实际测试效果并不理想,并且平均的响应时间也长了,所以单纯靠提升线程数量是不能一直得到性能提升的;

      2.4 设置最大等待队列数

        默认情况下,请求发送到tomcat,如果tomcat正忙,那么该请求会一直等待。这样虽然可以保证每个请求都能请求到,但是请求时间就会变长;

        有些时候,我们也不一定要求请求一定等待,可以设置最大等待队列大小,如果超过就不等待了。这样虽然有些请求时失败的,但是请求时间会变短。

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="100" prestartminSpareThreads="true" axQueueSize="100"/>

        测试结果:

          

        结论:

          响应时间,吞吐量这2个指标需要找到平衡才能达到更好的性能;

    3.设置nio2的运行模式

      将最大线程设置为500进行测试:

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" axQueueSize="100"/>

      设置nio2:   

        <Connector executor="tomcatThreadPool"
                   port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
                   connectionTimeout="20000"
                   redirectPort="8443" />

      测试结果:

        

         可以看到,平均响应时间有缩短,吞吐量有提升,可以得到结论:nio2的性能要高于nio;

        

  • 相关阅读:
    重写Django登录认证,实现用户名或者手机均可登录
    Django media文件夹详解
    Django admin使用
    python极验验证部署
    django 分页
    模板语言控制往哪个地址提交时,如果不填,默认往当前地址提交,也可以用request方法获取当前地址提交
    HashMap、Hashtable、LinkedHashMap、TreeMap、ConcurrentHashMap的区别
    ArrayList、LinkedList、Vector、CopyOnWriteArrayList的区别和源码分析
    谈谈线程池的核心参数,描述核心流程、应该怎么正确使用
    深入CAS的底层实现机制,以及对应的使用风险
  • 原文地址:https://www.cnblogs.com/wnwn/p/12448713.html
Copyright © 2011-2022 走看看