<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Terry.Li-彬

    虛其心,可解天下之問;專其心,可治天下之學(xué);靜其心,可悟天下之理;恒其心,可成天下之業(yè)。

      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      143 隨筆 :: 344 文章 :: 130 評(píng)論 :: 0 Trackbacks

    一、分布式實(shí)現(xiàn)原理

    ???????

    ??????? 如上圖所示,主要通過 Apache-Server 作為中轉(zhuǎn)服務(wù)器,實(shí)現(xiàn)多個(gè) tomcat 服務(wù)器之間的分布式處理,用戶直接請(qǐng)求 Apache-Server ,然后 Apache-Server 會(huì)將請(qǐng)求分發(fā)到具體的 tomcat-server ,之后 tomcat-server 響應(yīng)客戶請(qǐng)求并返回結(jié)果到 Apache-Server ,最后 Apache-Server 返回結(jié)果給用戶

    ?

    二、負(fù)載均衡

    文件說明:

    mod_jk.conf

    主要定義 mod_jk 模塊的位置以及 mod_jk 模塊的連接日志設(shè)置,還有定義 worker.properties 文件的位置。 ?

    worker.properties?
    定義 worker 的參數(shù),主要是連接 tomcat 主機(jī)的地址和端口信息。如果 Tomcat apache 不在同一臺(tái)機(jī)器上,或者需要做多臺(tái)機(jī)器上 tomcat 的負(fù)載均衡只需要更改 workers.properties 文件中的相應(yīng)定義即可。

    ?

    APACHE_HOME %為你的安裝目錄 ?

    ?

    環(huán)境說明:

    ??????? 主要使用了一個(gè) Apache Server 和兩個(gè) Tomcat ,在同一臺(tái)電腦上進(jìn)行測(cè)試。

    ?

    1.? 準(zhǔn)備軟件

    Jdk1.6

    下載地址: http://java.sun.com

    tomcat -6.0.29

    下載地址: http://jakarta.apache.org

    apache_2.2.4-win32-x86-no_ssl.msi

    下載地址: http://httpd.apache.org/download.cgi

    mod_jk-1.2.31-httpd-2.0.52.so?( 主要作用是建立 Apache Server Tomcat 之間的連接 )

    下載地址: http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/

    ?

    ??????? 說明: apache-server 安裝完成后,可以在瀏覽器中輸入 http://localhost/ 來測(cè)試,如果出現(xiàn) ” It works!” 則表示安裝成功。


    2.?
    安裝 mod_jk 連接模塊

    安裝好 Jdk 、 tomcat 、 apache , 加入 mod_jk 連接模塊,就是把 mod_jk- 1.2.31 -httpd-2.2.3.so 文件 拷貝到% APACHE_HOME \modules 下,把 jk 模塊的配置放到單獨(dú)的文件中來,在% APACHE_HOME \conf 目錄新建 mod_jk.conf 、 workers.properties 文件。

    ?

    httpd.conf 最后加上

    ??????? #?JK?module?settings

    Include?conf/mod_jk.conf? ?

    說明:以上表示將 mod_jk.conf 配置文件包含進(jìn)來

    ?


    3.?
    修改 mod_jk.conf 文件

    為了保持 httpd.conf 文件的簡(jiǎn)潔,把 jk 模塊的配置放到單獨(dú)的文件中來。

    ??????

    mod_jk.conf 文件中添加以下內(nèi)容:

    # Load mod_jk2 module

    LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so

    ?

    # Where to find workers.properties( 引用 workers 配置文件 )

    JkWorkersFile conf/workers.properties

    ?

    # Where to put jk logs(log 文件路徑 )

    JkLogFile logs/mod_jk2.log

    ?

    # Set the jk log level [debug/error/info](log 級(jí)別 )

    JkLogLevel info

    ??????

    # Select the log format(log 格式 )

    JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "

    # JkOptions indicate to send SSL KEY SIZE,

    JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories

    ?

    # JkRequestLogFormat set the request format

    JkRequestLogFormat "%w %V %T"

    ?

    # Send JSPs for context / to worker named loadBalancer(URL 轉(zhuǎn)發(fā)配置,匹配的 URL 才轉(zhuǎn)發(fā)到 tomcat 進(jìn)行處理 )

    JkMount /*.jsp controller

    # JkMount /*.* loadBalancer

    ??????

    4.? 修改 workers.properties 文件

    workers.properties 文件中添加以下內(nèi)容:

    #server? 列表

    worker.list =? controller,tomcat1,tomcat2

    ?

    # tomcat1(ajp13? 端口號(hào),在tomcatserver.xml配置,默認(rèn)8009)

    worker.tomcat1.port=8009

    #tomcat 的主機(jī)地址,如不為本機(jī),請(qǐng)?zhí)顚?span lang="EN-US">ip地址

    worker.tomcat1.host=localhost

    worker.tomcat1.type=ajp13

    #server 的加權(quán)比重,值越高,分得的請(qǐng)求越多

    worker.tomcat1.lbfactor = 1

    ?

    # tomcat2

    worker.tomcat2.port=9009

    worker.tomcat2.host=localhost

    worker.tomcat2.type=ajp13

    worker.tomcat2.lbfactor = 1

    ?

    # controller( 負(fù)載均衡控制器)

    worker.controller.type=lb

    #? 指定分擔(dān)請(qǐng)求的tomcat

    worker.controller.balanced_workers=tomcat1,tomcat2

    #worker.controller.sticky_session=true

    說明:此文件配置了 2 個(gè) tomcat 服務(wù)器進(jìn)行負(fù)載均衡處理

    ???

    5.? 修改 tomcat 配置文件 server.xml

    ??????? 更改其中一個(gè)的設(shè)置打開 tomcat2/conf/server.xml 文件,修改里面所有的端口設(shè)置,將 8 改為 9 ,如下: ??????
    ?



    6.?
    編寫一個(gè)測(cè)試頁(yè)面 teat1.jsp

    ??????? 建立一個(gè) test web 應(yīng)用,里面新建一個(gè) test1.jsp, 內(nèi)容為

    <% @?page?language = " java " ?contentType = " text/html;?charset=UTF-8 "

    ????pageEncoding
    = " UTF-8 "
    %>

    <! DOCTYPE?html?PUBLIC?"-//W3C//DTD?HTML?4.01?Transitional//EN"?"http://www.w3.org/TR/html4/loose.dtd" >

    < html >

    < head >

    < meta? http-equiv ="Content-Type" ?content ="text/html;?charset=UTF-8" >

    < title > test1 </ title >

    </ head >

    < body >

    <% ?

    ???System.out.println(
    " =========================== " );

    %>

    </ body >

    </ html >

    ?


    7.?
    啟動(dòng)服務(wù)器并進(jìn)行測(cè)試

    ??????? 依次啟動(dòng) apache-server 、 tomcat1 、 tomcat2 ,通過 ? http://localhost/test/test1.jsp ? 訪問,查看 tomcat1 的窗口,可以看到打印了一行 "==========" ,再刷新一次, tomcat2 也打印了一條,再刷新,可以看到請(qǐng)求會(huì)被 tomcat1,tomcat2 輪流處理 , 實(shí)現(xiàn)了負(fù)載均衡

    ?


    三、集群
    (session復(fù)制 )

    只配置負(fù)載均衡還不行,還要 session 復(fù)制,也就是說其中任何一個(gè) tomcat 的添加的 session ,是要同步復(fù)制到其它 tomcat , ? 集群內(nèi)的 tomcat 都有相同的 session

    ?

    1. tomcat 配置

    1.1? 修改 tomcat1, tomcat2 server.xml 文件添加集群內(nèi)容, tomcat5.5 無需添加,只需要去掉注釋符, tomcat6.0 需要添加,內(nèi)容如下:

    <Cluster className="org.apache.catalina.cluster.tcp.SimpleTcpCluster"

    ?????????????????managerClassName="org.apache.catalina.cluster.session.DeltaManager"

    ?????????????????expireSessionsOnShutdown="false"

    ?????????????????useDirtyFlag="true"

    ?????????????????notifyListenersOnReplication="true">

    ?

    ????????????<Membership

    ? ???????????????className="org.apache.catalina.cluster.mcast.McastService"

    ????????????????mcastAddr="228.0.0.4"

    ????????????????mcastPort="45564"

    ????????????????mcastFrequency="500"

    ????????????????mcastDropTime="3000"/>

    ?

    ????????????<Receiver

    ?????????? ??????className="org.apache.catalina.cluster.tcp.ReplicationListener"

    ????????????????tcpListenAddress="auto"

    ??? ?????????????tcpListenPort="4001"

    ????????????????tcpSelectorTimeout="100"

    ????????????????tcpThreadCount="6"/>

    ?

    ????????????<Sender

    ?????????? ??????className="org.apache.catalina.cluster.tcp.ReplicationTransmitter"

    ????????????????replicationMode="pooled"

    ????????????????ackTimeout="15000"

    ????????????????waitForAck="true"/>

    ?

    ????????????<Valve className="org.apache.catalina.cluster.tcp.ReplicationValve"

    ???????????????????filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;"/>

    ??????????????????

    ????????????<Deployer className="org.apache.catalina.cluster.deploy.FarmWarDeployer"

    ??????????????????????tempDir="/tmp/war-temp/"

    ??????????????????????deployDir="/tmp/war-deploy/"

    ??????????????????????watchDir="/tmp/war-listen/"

    ??????????????????????watchEnabled="false"/>

    ?????????????????????

    ???? ??????? ???????<ClusterListener className="org.apache.catalina.cluster.session.ClusterSessionListener"/>

    ????????</Cluster>

    分別添加以上內(nèi)容后,在 tomcat2 中,修改 tcpListenPort="4001"? 4002

    ?

    1.2. Engine 增加 jvmRoute 屬性設(shè)置, jvmRoute 的值來自于 workers.properties 文件所設(shè)置的服務(wù)器名稱。

    <Engine name="Catalina" defaultHost="localhost"? jvmRoute="tomcat1" >

    ?

    #server? 列表

    worker.list =? controller,tomcat1,tomcat2

    2.? 添加 test.jsp 頁(yè)面

    2.1. test.jsp 添加以下內(nèi)容:

    <% @?page?contentType = " text/html;?charset=UTF-8 " %>

    <% @?page?import = " java.util.* " %>

    < html >

    < head >

    < title > Cluster?App?Test </ title >

    </ head >

    < body >

    Server?Info:

    <%

    ??out.println(request.getLocalAddr()?
    + ? " ?:? " ? + ?request.getLocalPort()? + ? " <br> " );

    %>

    <%

    ??out.println(
    " <br>?ID? " ? + ?session.getId()? + ? " <br> " );

    ??
    // ?如果有新的?Session?屬性設(shè)置

    ??
    String ?dataName? = ?request.getParameter( " dataName " );

    ??
    if ?(dataName?! = ? null ? && ?dataName.length()? > ? 0 )?{

    ?????
    String ?dataValue? = ?request.getParameter( " dataValue " );

    ?????session.setAttribute(dataName,?dataValue);

    ??}

    ??out.print(
    " <b>Session?列表</b> " );

    ??Enumeration?e?
    = ?session.getAttributeNames();

    ??
    while ?(e.hasMoreElements())?{

    ?????
    String ?name? = ?( String )?e.nextElement();

    ?????
    String ?value? = ?session.getAttribute(name).toString();

    ?????out.println(name?
    + ? " ?=? " ? + ?value? + ? " <br> " );

    ?????System.out.println(name?
    + ? " ?=? " ? + ?value);

    ??}

    %>

    < form? action ="test.jsp" ?method ="POST" >

    名稱:
    < input? type =text? size =20? name ="dataName" > ? < br >

    值:
    < input? type =text? size =20? name ="dataValue" > ? < br >

    < input? type =submit ></ form >

    </ body >

    </ html >

    ?

    2.2.? 修改 web.xml 文件,加入 <distributable/> 節(jié)點(diǎn),如下所示:

    <? xml?version="1.0"?encoding="UTF-8" ?>

    < web-app? xmlns:xsi ="http://www.w3.org/2001/XMLSchema-instance" ?xmlns ="http://java.sun.com/xml/ns/javaee" ?xmlns:web ="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" ?xsi:schemaLocation ="http://java.sun.com/xml/ns/javaee?http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" ?id ="WebApp_ID" ?version ="2.5" >

    ??
    < display-name > test </ display-name >

    ??
    < distributable />

    ??
    < welcome-file-list >

    ????
    < welcome-file > index.html </ welcome-file >

    ????
    < welcome-file > index.htm </ welcome-file >

    ????
    < welcome-file > index.jsp </ welcome-file >

    ????
    < welcome-file > default.html </ welcome-file >

    ????
    < welcome-file > default.htm </ welcome-file >

    ????
    < welcome-file > default.jsp </ welcome-file >

    ??
    </ welcome-file-list >

    </ web-app >

    ?

    3. Session 復(fù)制測(cè)試

    測(cè)試步驟如下:

    1)???????? 啟動(dòng) apache-server 、 tomcat1 、 tomcat2

    2)???????? 訪問 http://localhost/test/test.jsp ,輸入名稱: test0001 、值: 123 并點(diǎn)擊“提交查詢內(nèi)容”按鈕,顯示效果如下:

    如上圖所示, tomcat1 創(chuàng)建了一個(gè)新的 session , session 中有屬性 test0001, 值為 123
    ?

    3)???????? 關(guān)閉 tomcat1 服務(wù)器, tomcat1 端口為 8080 ,如下圖:

    4)???????? 在頁(yè)面中再次點(diǎn)擊“提交查詢內(nèi)容”按鈕,效果如下:

    ????前端頁(yè)面并沒有發(fā)生改變,接下來查看后臺(tái)情況:
    ????

    ????
    如圖所示,可以發(fā)現(xiàn) session 已成功復(fù)制到 tomcat2 中,以此證明 tomcat 集群已配置成功。

    ?

    ?

    5)???????? 另外來看看不關(guān)閉 tomcat1 服務(wù)器再次提交的情況

    ???????
    如圖所示,請(qǐng)求并沒有轉(zhuǎn)發(fā)到 tomcat2 服務(wù)器,而是再次轉(zhuǎn)回 tomcat1 服務(wù)器,這種情況是由于配置了 jvmRoute 所致,以個(gè)人理解,配置了此屬性后, apache-server 會(huì)根據(jù) session 情況來進(jìn)行路由,同一個(gè) session 會(huì)轉(zhuǎn)發(fā)給同一個(gè)服務(wù)器。

    ?

    ?

    6)???????? 打開一個(gè)新的 IE 窗口,并訪問 http://localhost/test/test.jsp

    ?????????????
    ???????????????
    ?????????????
    新窗口的請(qǐng)求轉(zhuǎn)發(fā)到了 tomcat2 服務(wù)器, session id DD9E6C8181653B9BCCF534FC8760B264.tomcat2 ,根據(jù)測(cè)試結(jié)果可以說明,在不發(fā)生服務(wù)器關(guān)閉的情況下,每個(gè) session 會(huì)綁定到同一個(gè)服務(wù)器中,而不會(huì)在服務(wù)器間發(fā)生復(fù)制。

    posted on 2011-06-22 22:18 禮物 閱讀(8856) 評(píng)論(2)  編輯  收藏

    評(píng)論

    # re: Apache Http Server與Tomcat實(shí)現(xiàn)負(fù)載均衡和集群 2014-03-14 00:39 秦真
    集群后,創(chuàng)建的 test1.jsp 放在哪兒?  回復(fù)  更多評(píng)論
      

    # re: Apache Http Server與Tomcat實(shí)現(xiàn)負(fù)載均衡和集群[未登錄] 2015-08-28 09:29
    講的很詳細(xì),受教了  回復(fù)  更多評(píng)論
      


    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。

    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 1a级毛片免费观看| 成人自慰女黄网站免费大全| 最近2018中文字幕免费视频| 亚洲AV无码一区二区三区系列| 美女网站在线观看视频免费的| 亚洲日韩在线观看| 黄床大片免费30分钟国产精品| 国产91精品一区二区麻豆亚洲| 国产97视频人人做人人爱免费| 精品亚洲一区二区三区在线播放| 香蕉视频在线免费看| 国产亚洲AV无码AV男人的天堂 | 国产视频精品免费| 在线看亚洲十八禁网站| 亚洲免费在线观看| 91在线免费观看| 久久精品国产亚洲AV高清热| 91九色视频无限观看免费| 亚洲中文字幕久久精品无码A| 国产资源免费观看| 美女被免费网站91色| 亚洲人成亚洲精品| 最近最新MV在线观看免费高清| 亚洲AV香蕉一区区二区三区| 亚洲午夜精品第一区二区8050| 老司机69精品成免费视频| 91嫩草亚洲精品| 国产区卡一卡二卡三乱码免费| 一区二区三区免费精品视频 | 成人毛片免费观看视频大全| 国产精品亚洲专区一区| 久久久青草青青亚洲国产免观| 亚洲黄色免费网站| 苍井空亚洲精品AA片在线播放 | 国产又粗又猛又爽又黄的免费视频| igao激情在线视频免费| 亚洲bt加勒比一区二区| 免费视频中文字幕| 中文字幕视频免费在线观看| 亚洲已满18点击进入在线观看| 亚洲精品无码日韩国产不卡?V|