描述:
我们的 web 项目开发完成后,需要打包,部署到 Tomcat 服务器,项目上线时,我们需要对 Tomcat 进行优化配置,让每个 Tomcat 性能发挥到最佳;
这里我们从内存、并发、和缓存,三个方面进行优化;
1.内存优化
内存优化主要是对启动参数优化,修改 Tomcat 启动脚本 catalina.sh,添加 JAVA_OPTS 参数;
JAVA_OPTS 说明:
server 启用JDK的 server
-Xms JVM初始化时的最小内存
-Xmx JVM可使用的最大内存;
-XX: PermSize 内存永久保留区域
-XX:MaxPermSize 内存最大永久保留区域
以 服务器内存 2G 为例,配置如下:
JAVA_OPTS='-Xms1024m -Xmx2048m -XX: PermSize=256M -XX:MaxNewSize=256m -XX:MaxPermSize=256m'
配置完成后,重启 Tomcat;
2.并发优化
并发优化主要是修改 Tomcat / conf 配置文件中的 server.xml;
重点参数:
maxThreads 客户请求最大线程数
minSpareThreads 初始化时创建的 socket 线程数
maxSpareThreads 连接器的最大空闲 socket 线程数
enableLookups 若设为true, 则支持域名解析,可把 ip 地址解析为主机名
redirectPort 在需要基于安全通道的场合,把客户请求转发到基于SSL 的 redirectPort 端口
acceptAccount 监听端口队列最大数,满了之后客户请求会被拒绝(不能小于maxSpareThreads )
connectionTimeout 连接超时
minProcessors 服务器创建时的最小处理线程数
maxProcessors 服务器同时最大处理线程数
URIEncoding URL统一编码
配置示例:
<Connector port="8088"
protocol="HTTP/1.1"
maxHttpHeaderSize="8192"
maxThreads="1000"
minSpareThreads="100"