着重是 jvm 的内存大小的配置和 catalina 的线程数及队列等等.
JVM 的优化
Linux 修改 启动文件的参数 JAVA_OPTS
如果服务器只运行一个 Tomcat
8G 内存的机子配置:
JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms29696m -Xmx29696m -XX:NewSize=6144m -XX:MaxNewSize=9216m -XX:PermSize=1024m -XX:MaxPermSize=1024m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC"
16G
JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms13312m -Xmx13312m -XX:NewSize=3072m -XX:MaxNewSize=4096m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC"
32G
JAVA_OPTS="-Dfile.encoding=UTF-8 -server -Xms6144m -Xmx6144m -XX:NewSize=1024m -XX:MaxNewSize=2048m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:MaxTenuringThreshold=10 -XX:NewRatio=2 -XX:+DisableExplicitGC"
参数说明:
-Dfile.encoding: 默认文件编码
-server: 表示这是应用于服务器的配置, JVM 内部会有特殊处理的
-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=10: 设置垃圾最大年龄, 默认为: 15. 如果设置为 0 的话, 则年轻代对象不经过 Survivor 区, 直接进入年老代. 对于年老代比较多的应用, 可以提高效率. 如果将此值设置为一个较大值, 则年轻代对象会在 Survivor 区进行多次复制, 这样可以增加对象再年轻代的存活时间, 增加在年轻代即被回收的概论.
-XX:+DisableExplicitGC: 这个将会忽略手动调用 GC 的代码使得 System.gc() 的调用就会变成一个空调用, 完全不会触发任何 GC
Tomcat 8 配置
设置 Tomcat 相关变量:
- JAVA_HOME=/path/to/jdk1.8.0_72
- CATALINA_HOME=/path/to/tomcat8
- CATALINA_PID=$CATALINA_HOME/catalina.pid
如果使用 shutdown.sh 还无法停止 tomcat, 可以修改其配置: vim /usr/program/tomcat8/bin/shutdown.sh
把最尾巴这一行: exec "$PRGDIR"/"$EXECUTABLE" stop "$@"
改为: exec "$PRGDIR"/"$EXECUTABLE" stop 10 -force
Tomcat 8 优化
Tomcat 6/7/8 的优化参数有点不一样, 最好按下面的方式看一下官网这个文档是否还保留着这个参数
启动 tomcat, 访问该地址, 下面要讲解的一些配置信息, 在该文档下都有说明的:
文档: http://127.0.0.1:8080/docs/config
你也可以直接看网络版本:
Tomcat 8 文档: https://tomcat.apache.org/tomcat-8.0-doc/config/
如果你需要查看 Tomcat 的运行状态可以配置 tomcat 管理员账户, 然后登陆 Tomcat 后台进行查看
编辑 /opt/tomcat7/bin/conf/tomcat-users.xml 文件, 在里面添加下面信息:
- <role rolename="manager"/>
- <role rolename="manager-gui"/>
- <role rolename="admin"/>
- <role rolename="admin-gui"/>
- <user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/>
编辑配置文件: vim /usr/program/tomcat7/conf/server.xml
打开默认被注释的连接池配置:
默认值:
<!--
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="150" minSpareThreads="4"/>
-->
修改为:
- <Executor
- name="tomcatThreadPool"
- namePrefix="catalina-exec-"
- maxThreads="500"
- minSpareThreads="100"
- prestartminSpareThreads = "true"
- maxQueueSize = "100"
- />
重点参数解释:
maxThreads, 最大并发数, 默认设置 200, 一般建议在 500 ~ 800, 根据硬件设施和业务来判断
minSpareThreads,Tomcat 初始化时创建的线程数, 默认设置 25
prestartminSpareThreads, 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值, 如果不等于 true,minSpareThreads 的值就没啥效果了
maxQueueSize, 最大的等待队列数, 超过则拒绝请求
修改默认的链接参数配置:
默认值:
- <Connector
- port="8080"
- protocol="HTTP/1.1"
- connectionTimeout="20000"
- redirectPort="8443"
- />
修改为:
- <Connector
- executor="tomcatThreadPool"
- port="8080"
- protocol="org.apache.coyote.http11.Http11Nio2Protocol"
- connectionTimeout="20000"
- maxConnections="10000"
- redirectPort="8443"
- enableLookups="false"
- acceptCount="100"
- maxPostSize="10485760"
- compression="on"
- disableUploadTimeout="true"
- compressionMinSize="2048"
- acceptorThreadCount="2"
- compressableMimeType="text/html,text/xml,text/plain,text/CSS,text/javascript,application/javascript"
- URIEncoding="utf-8"
- />
重点参数解释:
protocol,Tomcat 8 设置 nio2 更好: org.apache.coyote.http11.Http11Nio2Protocol(如果这个用不了, 就用下面那个)
protocol,Tomcat 6,7 设置 nio 更好: org.apache.coyote.http11.Http11NioProtocol
enableLookups, 禁用 DNS 查询
acceptCount, 指定当所有可以使用的处理请求的线程数都被使用时, 可以放到处理队列中的请求数, 超过这个数的请求将不予处理, 默认设置 100
maxPostSize, 以 FORM URL 参数方式的 POST 提交方式, 限制提交最大的大小, 默认是 2097152(2 兆), 它使用的单位是字节. 10485760 为 10M. 如果要禁用限制, 则可以设置为 -1.
acceptorThreadCount, 用于接收连接的线程的数量, 默认值是 1. 一般这个指需要改动的时候是因为该服务器是一个多核 CPU, 如果是多核 CPU 一般配置为 2.
禁用 AJP(如果你服务器没有使用 Apache)
把下面这一行注释掉, 默认 Tomcat 是开启的.
<!-- <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> -->
目前优化的 tomcat 配置如下:
- <Connector port="8090" protocol="HTTP/1.1"
- connectionTimeout="2000000"
- redirectPort="8443"
- maxThreads="8000"
- maxPostSize="10485760"
- disableUploadTimeout="true"
- minSpareThread="1000" maxSpareThreads="2000"
- acceptCount="2000"
- maxConnections="-1"
- />
来源: http://www.bubuko.com/infodetail-2667527.html