- 環境概述
OS:Linux
Apache Http Server:2.2.21
安裝可以使用rpm或是抓source下來compile,建議前者
rpm –ivh apache-http-xxx.rpm
這裡請注意一下安裝的版本 - http.conf 參數設定
Proxy<VirtualHost *:80> 範例如下
ProxyPass targetPath fromPath | fromUrl
<VirtualHost/>
<VirtualHost *:80>
ProxyPass /app http://DomainName或IP:8888/app
ProxyPassReverse /app http://DomainName或IP:8888/app
<VirtualHost/>
上述的參數設定為,將某主機的http通訊協定下的Web application(app),對應到本台Web Server的app下。這樣的Proxy架構的設定對企業內的Web應用程式相當有用處,若是遇到Web Application Server掛點只需要修改Proxy對應,不需要動到dns等等,是個滿便宜的Proxy架構設定喔。﹝不過要注意Web Application要注意redirectc和forward等的撰寫,盡量不要有絕對IP的出現﹞
- Load Balance
不用花大錢就可以做到的做法,這方式我倒覺得適合目前的企業,像是IBM Websphere、Oracle Weblogic的Application Server也做得很好,可是反而太過了成為了bottom neck,另外就是License很可怕ㄚ,所以啦用這種方式反而不限定只有Java可以使用。
Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
- 設定Session Sticky模式,不讓其Session循序變動
BalancerMember http://DomainName1或IP1:8888/app route=1
BalancerMember http://DomainName2或IP2:9999/app route=2
ProxySet stickysession=ROUTEID
<VirtualHost *:80>
ProxyPass /appbalancer://cluster
ProxyPassReverse /app balancer://cluster
<VirtualHost/>
真的不用太複雜這樣就可以進行LoadBalance很好用ㄚ,不過請注意Web Application資料同步問題需要處理喔。
留言
張貼留言