反向代理负载均衡 (Apache2+Tomcat7/8)
使用代理服务器可以将请求转发给内部的Web服务器,让代理服务器将请求均匀地转发给多台内部Web服务器之一上,从而达到负载均衡的目的。这种代理方式与普通的代理方式有所不同,标准代理方式是客户使用代理访问多个外部Web服务器,而这种代理方式是多个客户使用它访问内部Web服务器,因此也被称为反向代理模式。
此次使用的代理为mod_proxy的方式来实现的,因为在Apache2以上的版本中已经集成了,因此不需要再另行安装和配置了,只需要把注释去掉即可,此去掉的配置,个人感觉与Apache虚拟机的实现相类似,去掉以下模块的注释:
LoadModule lbmethod_bybusyness_module modules/mod_lbmethod_bybusyness.so
LoadModule lbmethod_byrequests_module modules/mod_lbmethod_byrequests.so
LoadModule lbmethod_bytraffic_module modules/mod_lbmethod_bytraffic.so
LoadModule heartbeat_module modules/mod_heartbeat.so
LoadModule lbmethod_heartbeat_module modules/mod_lbmethod_heartbeat.so
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
LoadModule proxy_http_module modules/mod_proxy_http.so
LoadModule proxy_connect_module modules/mod_proxy_connect.so
LoadModule proxy_scgi_module modules/mod_proxy_scgi.so
#如果使用的是最新版Apache,可以打开websocket代理
#LoadModule mod_proxy_wstunnel modules/mod_proxy_wstunnel.so
在这里,我们通过虚拟主机的方式配置(如果对虚拟主机配置方式有疑问,请参考:Apache/Ngnix虚拟主机(虚拟站点)的配置)
这里我们选择基于端口的虚拟主机配置,在httpd.conf中修改如下行
#Include conf/vhosts.conf的注释也去掉,配置的负载均衡,然后打开vhosts.conf,添加如下配置
Listen 9000
#虚拟机配置,负载均衡配置 注意空格
<VirtualHost *:9000>
<Proxy balancer://mycluster>
BalancerMember ajp://127.0.0.1:8092 loadfactor=1 route=node1 ttl=120 timeout=15 smax=5 max=20
BalancerMember ajp://127.0.0.1:8093 loadfactor=1 route=node2 ttl=120 timeout=15 smax=5 max=20
ProxySet lbmethod=byrequests
</Proxy>
ProxyRequests Off
ProxyPass / balancer://mycluster/ stickysession=JSESSIONID nofailover=Off
ProxyPassReverse / balancer://mycluster/
ErrorLog "logs/proxy/error.log"
CustomLog "logs/proxy/access.log" combined
</VirtualHost>
其中: 127.0.0.1:8092 和 127.0.0.1:8093为两个Tomcat负载服务器,住哟这里使用的是ajp端口。
loadfactor=1 route=tomcat8_local smax=5 max=20 ttl=120 retry=300 timeout=15 这个为配置的参数,最大链接,超时,等等route=tomcat8_local 可以不写,写的话一般和Tomcat server.xml中的Engine的jvm属性对应
ProxySet lbmethod=byrequests 为实现负载均衡的方式,共有四种类型
#lbmethod=byrequests 按照请求次数均衡(默认)
#lbmethod=bytraffic 按照流量均衡
#lbmethod=bybusyness 按照繁忙程度均衡(总是分配给活跃请求数最少的服务器)#lbmethod=heartbeat 通过心跳检测最好的
route=tomcat8_local 根据这个route的值,分别在两个Tomat中的Service.xml的 Engine 节点配置上jvmRoute的内容,如下: <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat8_local">和以及jvmRoute="tomcat8_250" ,不过我在测试是,感觉如果不配置,也不会影响程序的执行。如果配置,那么session值将会带后缀,后缀名为此处的节点名称
此外,我们的Tomcat也需要有多个,这里为了模拟,为创建2个Tomcat虚拟主机(Tomcat虚拟主机的创建请参考 Tomcat 虚拟主机或二级域名配置)
这里我们同样配置基于端口的虚拟主机
在Server节点下新增加2个Service节点,注意我们这里通过balance+ajp方式实现,因此,请配置ajp的Connector,此外,我们需要给Engine设置jvmRoute名称(可以省略)
<Service name="myVirtualService">
<Connector connectionTimeout="20000" port="8082" protocol="HTTP/1.1" redirectPort="8443"/>
<Connector port="8092" protocol="AJP/1.3" redirectPort="8443" />
<Engine name="myVirtualServiceEngine" debug="0" defaultHost="localhost" jvmRoute="node1">
<Host appBase="webapps2" autoDeploy="true" name="localhost" unpackWARs="true">
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access8082_log." suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
<Context path="" docBase="." debug="0" reloadable="true"/>
</Host>
</Engine>
</Service>
<Service name="myVirtualService2">
<Connector connectionTimeout="20000" port="8083" protocol="HTTP/1.1" redirectPort="8443"/>
<Connector port="8093" protocol="AJP/1.3" redirectPort="8443" />
<Engine name="myVirtualServiceEngine2" debug="0" defaultHost="localhost" jvmRoute="node2">
<Host appBase="webapps2" autoDeploy="true" name="localhost" unpackWARs="true">
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access8082_log." suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
<Context path="" docBase="." debug="0" reloadable="true"/>
</Host>
</Engine>
</Service>
注意,我们这里实现的是ajp方式的代理,如果想要实现http方式的代理,那么修改协议和端口即可
<Proxy balancer://hotcluster>
BalancerMember http://www2.example.com:8080 loadfactor=1
BalancerMember http://www3.example.com:8080 loadfactor=2
ProxySet lbmethod=bytraffic
ProxySet keepalive=On
</Proxy>
ProxySet balancer://hotcluster lbmethod=bytraffic timeout=15