跳到主要內容

使用Apache Http Server進行Proxy和LoadB alance


  1. 環境概述
    OS:Linux
    Apache Http Server:2.2.21
    安裝可以使用rpm或是抓source下來compile,建議前者
    rpm –ivh apache-http-xxx.rpm
    這裡請注意一下安裝的版本
  2. 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循序變動
    <Proxy balancer://cluster failonstatus=404,301,500 nofailover=Off>
         BalancerMember http://DomainName1或IP1:8888/app route=1
         BalancerMember http://DomainName2或IP2:9999/app route=2
         ProxySet stickysession=ROUTEID
    <Proxy/>

    <VirtualHost *:80>
         ProxyPass /appbalancer://cluster
         ProxyPassReverse /app balancer://cluster
    <VirtualHost/>    
     

    真的不用太複雜這樣就可以進行LoadBalance很好用ㄚ,不過請注意Web Application資料同步問題需要處理喔。



留言