精华内容
下载资源
问答
  • tomcat 优化

    2018-09-30 15:18:52
    tomcat 优化 好书!
  • tomcat优化

    2012-10-17 14:15:46
    tomcat优化
  • Tomcat优化

    千次阅读 2019-08-05 11:14:47
    Tomcat优化 tomcat服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了。对于tomcat的优化,主要是从2个方面入手,一是,tomcat自身的配置,另一个是tomcat所运行的jvm虚拟机的优化。 ...

    Tomcat优化

    tomcat服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了。对于tomcat的优化,主要是从2个方面入手,一是,tomcat自身的配置,另一个是tomcat所运行的jvm虚拟机的优化。

    1、Tomcat配置优化

    1.1、部署安装tomcat

    下载并安装:https://tomcat.apache.org/download-80.cgi
    在这里插入图片描述
    进入tomcat的conf目录下,修改tomcat的tomcat-users.xml文件,在标签tomcat-users前面添加:

    <role rolename="manager-gui"/>
    <role rolename="manager"/>
    <role rolename="admin"/>
    <role rolename="admin-gui"/>
    <user username="tomcat" password="tomcat" roles="manager,manager-gui,admin,admin-gui"/>
    

    如果使用的是tomcat 8的话,还得修改webapps/manager/META-INF/context.xml,注释掉

    <Valve className="org.apache.catalina.valves.RemoteAddrValve"  allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
    

    注释完成之后,就可以进入bin目录下启动tomcat了,访问tomcat:http://IP:8080
    在这里插入图片描述
    然后点击“Server Status”,输入刚才配置的用户名tomcat和密码tomcat之后,就可以查看当前tomcat的状态信息了。
    在这里插入图片描述

    1.2、禁用AJP连接

    在服务状态页面中可以看到,默认状态下会启用AJP服务,并且占用8009端口。
    在这里插入图片描述
    什么是AJP呢?
    AJP(Apache JServer Protocol)。
    AJPv13协议是面向包的。WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP连接到servlet容器,并且在多个请求和响应周期过程会重用连接。
    在这里插入图片描述
    我们一般是使用Nginx + Tomcat的架构,用不着AJP协议,所以把AJP连接器禁用。
    修改conf下的server.xml文件,将AJP服务禁用掉即可。

    <!-- <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> -->
    

    然后重启tomcat,查看效果,
    在这里插入图片描述
    可以看到AJP服务不存在了。

    1.3、执行器(线程池)

    在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能。
    修改server.xml

    <!‐‐将注释打开‐‐>
    <Executor name="tomcatThreadPool" namePrefix="catalina‐exec‐" 	maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>
    <!‐‐
    	参数说明:
    	maxThreads:最大并发数,默认设置 200,一般建议在 500 ~ 1000,根据硬件设施和业务来判断
    	minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25
    	prestartminSpareThreads: 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了
    	maxQueueSize,最大的等待队列数,超过则拒绝请求
    ‐‐>
    <!‐‐在Connector中设置executor属性指向上面的执行器‐‐>
    <Connector executor="tomcatThreadPool" port="8080" protocol="HTTP/1.1"	connectionTimeout="20000"	redirectPort="8443" /> 
    

    保存退出,重新启动,查看效果。
    在这里插入图片描述
    在页面中显示最大线程数为-1,这个是正常的,仅仅是显示的问题,实际使用的指定的值。
    也有人遇到这样的问题:https://blog.csdn.net/weixin_38278878/article/details/80144397

    1.4、3种运行模式

    tomcat的运行模式有3种:

    1. bio
      默认的模式,性能非常低下,没有经过任何优化处理和支持。
    2. nio
      nio(new I/O),是Java SE1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)。Java.nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,因此,nio也被看成是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能。
      3.apr
      安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能。

    推荐使用nio,不过,在tomcat 8中有最新的nio2,速度更快,建议使用nio2.
    设置nio2:,修改server.xml,将原来8080端口的Connector修改为:

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

    在这里插入图片描述
    可以看到,已经设置为nio2了。

    展开全文
  • Tomcat 优化

    2020-06-11 21:09:28
    Tomcat 优化 Tomcat安装 进入Tomcat官网https://tomcat.apache.org/,选择相应版本,进行下载。 点击Download进入如下页面即可下载 不管是安装版还是解压版,安装都很简单。安装目录如下: Tomcat使用 Windows...

    Tomcat 优化

    Tomcat安装

    进入Tomcat官网https://tomcat.apache.org/,选择相应版本,进行下载。
    在这里插入图片描述

    点击Download进入如下页面即可下载
    在这里插入图片描述

    不管是安装版还是解压版,安装都很简单。安装目录如下:
    在这里插入图片描述

    Tomcat使用

    Windows使用bat文件启动,Linux使用sh文件启动
    在这里插入图片描述

    Windows版在bin目录运行service.bat install Tomcat即可添加服务,设置开机自启。

    Tomcat 配置优化

    1.关闭AJP

    AJP(Apache JServer Protocol)AJPv13协议是面向包的。WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP连接到servlet容器,并且在多个请求和响应周期过程会重用连接。

    修改conf下的server.xml文件,将AJP服务禁用掉即可。
    <!-- 禁用AJP连接 -->
    <!-- <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> -->
    

    2.线程池

    在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能。

    修改server.xml文件:

    <!--执行器 将注释打开-->
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
    maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>
    
    <!--
    参数说明:
    maxThreads:最大并发数,默认设置 200,一般建议在 500 ~ 1000,根据硬件设施和业务来判断
    minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25
    prestartminSpareThreads: 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了
    maxQueueSize,最大的等待队列数,超过则拒绝请求
    -->
    
    <!--在Connector中设置executor属性指向上面的执行器-->
    <Connector executor="tomcatThreadPool" port="8080" protocol="HTTP/1.1"
    connectionTimeout="20000"
    redirectPort="8443" />
    

    连接器

    <Connector executor="tomcatThreadPool" port="8080"                          protocol="org.apache.coyote.http11.Http11Nio2Protocol"
    connectionTimeout="20000" redirectPort="8443"
    enableLookups="false" maxPostSize="10485760" URIEncoding="UTF-8"      acceptCount="100" acceptorThreadCount="2" disableUploadTimeout="true" maxConnections="10000" SSLEnabled="false"/>
    

    执行器

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

    3.设置运行模式

    bio

    性能非常低下,没有经过任何优化处理和支持

    nio

    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)更好的并发运行性能。Tomcat8默认使用nio运行模式

    apr

    安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能

    推荐使用nio,在tomcat8中有最新的nio2,速度更快,建议使用nio2

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

    6.JVM调优

    在/bin/catalina.sh文件第一行添加如下参数,gc日志输出到/logs/gc.log

    JAVA_OPTS="-XX:+UseParallelGC -XX:+UseParallelOldGC -Xms64m -Xmx512m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:../logs/gc.log"
    

    将gc.log文件上传到gceasy.io查看gc中是否存在问题。上传文件后需要等待一段时间,需要耐心等待。

    调整年轻代大小

    JAVA_OPTS="-XX:+UseParallelGC -XX:+UseParallelOldGC -Xms128m -Xmx1024m -XX:NewSize=64m -XX:MaxNewSize=256m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:../logs/gc.log"
    

    设置G1垃圾回收器

    JAVA_OPTS="-XX:+UseG1GC -XX:MaxGCPauseMillis=100 -Xms128m -Xmx1024m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:../logs/gc.log"
    

    JVM配置最佳实践(具体配置还需根据服务器实际配置决定)

    JAVA_OPTS="-Dfile.encoding=UTF-8-server -Xms1024m -Xmx2048m -XX:NewSize=512m -XX:MaxNewSize=1024m -XX:PermSize=256m -XX:MaxPermSize=256m -XX:MaxTenuringThreshold=10-XX:NewRatio=2 -XX:+DisableExplicitGC"
    

    参数说明

    file.encoding 默认文件编码

    -Xmx1024m 设置JVM最大可用内存为1024MB

    -Xms1024m 设置JVM最小内存为1024m。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。

    -XX:NewSize 设置年轻代大小

    -XX:MaxNewSize 设置最大的年轻代大小

    -XX:PermSize 设置永久代大小

    -XX:MaxPermSize 设置最大永久代大小

    -XX:NewRatio=4 设置年轻代(包括Eden和两个Survivor区)与终身代的比值(除去永久代)。设置为4,则年轻代与终身代所占比值为1:4,年轻代占整个堆栈的1/5

    -XX:MaxTenuringThreshold=0 设置垃圾最大年龄,默认为:15。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。

    -XX:+DisableExplicitGC 这个将会忽略手动调用GC的代码使得System.gc()的调用就会变成一个空调用,完全不会触发任何GC。

    展开全文

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 9,451
精华内容 3,780
关键字:

tomcat优化