Tomcat作为广泛使用的Java Web服务器和Servlet容器,其高效部署与性能优化对于生产环境至关重要。以下从部署策略和性能优化两方面进行系统说明:
# 使用自动化脚本示例
#!/bin/bash
# 自动部署脚本
TOMCAT_HOME=/opt/tomcat
WEBAPP_NAME=myapp
WAR_FILE=target/${WEBAPP_NAME}.war
# 停止Tomcat
$TOMCAT_HOME/bin/shutdown.sh
# 备份旧版本
cp -r $TOMCAT_HOME/webapps/$WEBAPP_NAME $TOMCAT_HOME/backup/$WEBAPP_NAME_$(date +%Y%m%d)
# 清理工作目录
rm -rf $TOMCAT_HOME/webapps/$WEBAPP_NAME*
rm -rf $TOMCAT_HOME/work/Catalina/localhost/$WEBAPP_NAME
# 部署新版本
cp $WAR_FILE $TOMCAT_HOME/webapps/
$TOMCAT_HOME/bin/startup.sh
conf/catalina.properties中shared.loader)# catalina.sh中JVM参数示例
JAVA_OPTS="-server -Xms2048m -Xmx2048m -XX:MetaspaceSize=256m \
-XX:MaxMetaspaceSize=512m -Xmn768m \
-XX:+UseG1GC -XX:MaxGCPauseMillis=200 \
-XX:+DisableExplicitGC -XX:+HeapDumpOnOutOfMemoryError \
-XX:HeapDumpPath=/opt/tomcat/logs/heapdump.hprof"
<Connector port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
maxThreads="200" minSpareThreads="25"
maxConnections="10000"
acceptCount="100"
compression="on"
compressionMinSize="2048"
compressableMimeType="text/html,text/xml,text/plain,text/css,text/javascript,application/json"
connectionTimeout="20000"
redirectPort="8443"
enableLookups="false"
URIEncoding="UTF-8"/>
<!-- 配置Redis会话管理器 -->
<Manager className="org.apache.catalina.session.PersistentManager">
<Store className="org.apache.catalina.session.RedisSessionStore"
host="redis-server"
port="6379"
database="0"
password=""
maxInactiveInterval="1800"/>
</Manager>
<!-- context.xml中资源配置 -->
<Context>
<Resource name="jdbc/myDB" auth="Container"
type="javax.sql.DataSource"
maxTotal="100" maxIdle="30"
maxWaitMillis="10000"
username="user" password="pass"
driverClassName="com.mysql.cj.jdbc.Driver"
url="jdbc:mysql://localhost:3306/mydb"/>
<!-- 启用静态资源缓存 -->
<Resources cachingAllowed="true" cacheMaxSize="10240"/>
</Context>
# Nginx配置示例
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|css)$ {
root /data/static;
expires 30d;
access_log off;
}
location / {
proxy_pass http://tomcat_cluster;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
<!-- server.xml中集群配置 -->
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster">
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4" port="45564" frequency="500"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto" port="4000"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
</Channel>
</Cluster>
<!-- 异步访问日志配置 -->
<Valve className="org.apache.catalina.valves.AccessLogValve"
directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b %D"
rotatable="true"
asyncSupported="true"/>
定期维护
work、temp目录安全加固
性能测试验证
版本管理
通过以上优化组合,Tomcat可支持千级并发连接,响应时间可优化至毫秒级。建议根据实际业务负载进行针对性调优,并在变更前后进行充分的性能对比测试。