Ubuntu下搭建 Tomcat 集群的标准做法
一 环境准备与约定
二 配置 Tomcat 集群与会话复制
方式 A 快速默认集群(适合节点数较少,如少于10台)
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
<distributable/>
方式 B 显式配置(可控性与可观测性更好)
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<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" dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto" port="4000" autoBind="100"
selectorTimeout="5000" maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatchInterceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter=""/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
三 配置负载均衡
方案 1 Apache HTTP Server + mod_jk(AJP)
worker.list=loadbalancer,status
worker.tomcat1.port=8009
worker.tomcat1.host=192.168.0.11
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor=1
worker.tomcat2.port=8009
worker.tomcat2.host=192.168.0.12
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor=1
worker.loadbalancer.type=lb
worker.loadbalancer.balance_workers=tomcat1,tomcat2
worker.loadbalancer.sticky_session=1
worker.status.type=status
a2enmod jk
# /etc/apache2/mods-enabled/jk.conf 或 apache2.conf 中
LoadModule jk_module modules/mod_jk.so
JkWorkersFile /path/to/workers.properties
JkLogFile /var/log/apache2/mod_jk.log
JkLogLevel info
<VirtualHost *:80>
ServerName yourdomain.com
JkMount /* loadbalancer
JkMount /jk-status status
</VirtualHost>
方案 2 Nginx 或 HAProxy(HTTP)
upstream backend {
server 192.168.0.11:8080;
server 192.168.0.12:8080;
# 如需会话保持(粘性会话),可添加:ip_hash;
}
server {
listen 80;
location / {
proxy_pass http://backend;
}
}
frontend http-in
bind *:80
default_backend servers
backend servers
balance roundrobin
server s1 192.168.0.11:8080 check
server s2 192.168.0.12:8080 check
四 部署与验证
五 常见问题与优化