欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Tomcat学习笔记 - 【性能优化与监控】 博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

程序员文章站 2024-03-22 08:23:40
...

        在生产环境下,通常需要对Tomcat的一些参数进行设置以达到优化性能的目的。Tomcat运行于虚拟机JVM之上,因此对JVM的优化必不可少,另外机器的硬件、软件环境对服务器的运行效率至关重要。抛去其他因素不谈,下面仅介绍对Tomcat的有关参数进行优化设置。Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

 

【基本参数设置】
        修改Tomcat的/conf目录下面的server.xml文件,针对端口为8080的连接器添加如下参数:Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

    1. connectionTimeout:连接失效时间,单位为毫秒、默认为60s、这里设置为30s,如果用户请求在30s内未能进入请求队列,视为本次连接失败。

    2. keepAliveTimeout:连接的存活时间,默认和connectionTimeout一致,这里可以设为15s、这意味着15s之后本次连接关闭. 如果页面需要加载大量图片、js等静态资源,需要将参数适当调大一点、以免多次创建TCP连接。

     3. enableLookups:是否对连接到服务器的远程机器查询其DNS主机名,一般情况下这并不必要,因此设为false即可。

     4. URIEncoding:设置URL参数的编码格式为UTF-8编码,默认为ISO-8859-1编码。

     5. maxHttpHeaderSize:设置HTTP请求、响应的头部内容大小,默认为8192字节(8k),此处设置为32768字节(32k)、和Nginx的设置保持一致。

     6. maxThreads:最大线程数、用于处理用户请求的线程数目,默认为200、此处设置为300

     7. acceptCount:用户请求等候队列的大小,默认为100、此处设置为200

       Linux系统默认一个进程能够创建的最大线程数为1024、因此对高并发应用需要进行Linux内核调优,至此文件server.xml修改后的内容如下所示:Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

   <Connector port="8080" 
     protocol="HTTP/1.1" 
     redirectPort="8443" 
     connectionTimeout="30000" 
     keepAliveTimeout="15000"
     enableLookups="false"
     URIEncoding="UTF-8"
     maxHttpHeaderSize="32768"
     maxThreads="300"
     acceptCount="200"
   />

 

【线程池技术】Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

         默认情况下,Tomcat针对每个用户请求都单独创建一个线程,用户请求处理完成后又将线程立即销毁掉,在并发访问量很高的情况下,线程的创建和销毁会带来比较大的系统开销。因此有必要使用Tomcat提供的线程池功能,下面是设置Tomcat线程池的示例:

     1. 修改连接器的设置:指定executor的name为线程池的名字、同时去掉最大线程数maxThreads的设置。

  <Connector executor="tomcatThreadPool"
    port="8080" 
    protocol="HTTP/1.1" 
    redirectPort="8443" 
    connectionTimeout="30000" 
    keepAliveTimeout="15000"
    enableLookups="false"
    URIEncoding="UTF-8"
    maxHttpHeaderSize="32768"
    acceptCount="200"
  />

     2. 线程池参数的设置: Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

  <Executor name="tomcatThreadPool" 
    namePrefix="catalina-exec-" 
    maxThreads="300"
    minSpareThreads="50"
    maxIdleTime = "15000"
  />

    说明:

     1. 通过namePrefix属性指定用户线程的命名前缀为“catalina-exec-”。

     2. maxThreads为最大线程数,minSpareThreads为最小空闲线程数,maxIdleTime为最大空闲时间、单位为毫秒。

 

【使用Tomcat管理平台】Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

         修改Tomcat的conf目录下面的tomcat-users.xml文件,添加如下内容:

<user username="nick" password="123456" roles="manager"/>

         启动Tomcat之后,通过http://localhost:8080访问欢迎页,点击左侧的Tomcat Manager链接,输入上面设置的账号后,在打开的页面点击Server Status链接进入Tomcat监控页面,可以查看到JVM、Tomcat的一些环境信息,以及当前的用户线程数:Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控
Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控
 

上面这些,只是Tomcat性能优化的入门知识,就像之前说的,Tomcat依赖于JVM虚拟机,对JVM的参数优化和性能监控才是重中之重Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控,当然也更为复杂!

 

===============================

稍后继续!Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控

 

  • Tomcat学习笔记 - 【性能优化与监控】
            
    
    博客分类: Nginx/Tomcat/Jetty tomcat性能优化线程池监控
  • 大小: 306.2 KB