一:配置2个tomcat实例
1、调整它们的端口(shutdown,http或者ajp)
2、指定route
<Engine name="Catalina" defaultHost="localhost" jvmRoute="worker1">
两个tomcat实例,一个是worker1,一个是worker2。后面配置apache时要用到。
二:Apache上配置Proxy
1、加载相关代理模块
既然要使用代理方式访问,肯定要有代理模块才行的。在${apacheserver}/conf/httpd.conf中做如下配置:
启用proxy的命令是:
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
LoadModule proxy_http_module modules/mod_proxy_http.so
如果要配置AJP协议,要mod_proxy_ajp.so前面的#去掉。
2、定义反向代理和负载均衡
配置的源码是:
<IfModule proxy_balancer_module>
# define a Load Balance Proxy based HTTP protocol
<IfModule proxy_http_module>
<Proxy balancer://myHttpLB>
BalancerMember http://localhost:18080/examples loadfactor=80 route=worker1
BalancerMember http://localhost:28080/examples loadfactor=20 route=worker2
</Proxy>
ProxyRequests off
ProxyPass /examples balancer://myHttpLB/ stickySession=JSESSIONID nofailover=Off
ProxyPassReverse /examples balancer://myHttpLB/
</IfModule>
</IfModule>
上面的配置中,根据加载的模块启动了两个具有负载均衡功能的反向Proxy,一个是基于HTTP协议的,一个 是基于AJP协议的。
下面对HTTP协议的做一个说明:
<Proxy balancer://myHttpLB>
BalancerMember http://localhost:18080/examples loadfactor=80 route=worker1
BalancerMember http://localhost:28080/examples loadfactor=20 route=worker2
</Proxy>
这是定义一个Proxy,这个Proxy启用了负载均衡,名称是balancer://myHttpLB
有两个成员:worker1和worker2。权重分别为80、20。
ProxyPass /examples balancer://myHttpLB/ stickySession=JSESSIONID nofailover=Off
在访问http://apacheServerIp:port/examples 下的资源时,由交给负载均衡balancer://myHttpLB/ 来处理。这个配置表示:
stickySession 表示启用粘性会话。
Nofailover用于配置故障转移的。
ProxyPassReverse /examples balancer://myAjpLB/
用于调整由反向代理服务器发送的HTTP回应头中的URL
三:测试
访问http://localhost/examples。
examples是tomcat/webapps下的应用,所以肯定是可以访问到的。