Apache+Tomcat实现balance方式负载均衡

反向代理负载均衡 (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 &quot;%r&quot; %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 &quot;%r&quot; %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

 

转载于:https://my.oschina.net/ososchina/blog/848737

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值