Jboss 4.2.3 集群配置方法

fmms 12年前發布 | 43K 次閱讀 JBoss 應用服務器

一、準備工作

  • 安裝JDK 1.5或以上版本,Jboss 4.2.3,apache 2.2.x, mod_jk.so
  • 配置JAVA_HOME, JBOSS_HOME,APACHE_HOME環境變量
  • </ul>

    其中 mod_jk是apache服務器連接Jboss的插件

    二、配置
        假設有兩臺服務器都安裝了jboss, 其IP地址分別為192.168.1.100, 192.168.1.101
        為了理清配置的步驟,我們采用$JBOSS_HOME/server/default 的配置目錄,而不是直接使用$JBOSS_HOME/server/all的配置目錄。由于default配置不支持集群,因此首先需要將all配置的某些依賴包和配置文件拷貝到defaut配置的目錄中。

         2.1 拷貝用于集群的依賴包和配置文件
                將$JBOSS_HOME/all/lib下的 jbossha.jar, jgroups.jar和jboss-cache-jdk50.jar 拷貝到$JBOSS_HOME/default/lib 目錄下, 再把$JBOSS_HOME/server/all/deploy目錄里的cluster-service.xml 和jboss-web.cluster.sar文件夾拷貝到$JBOSS_HOME/server/default/deploy目錄下.  另一臺服務器也進行同樣操作
              
    jbossha.jar 用于加載org.jboss.ha.framework.server.ClusterPartition,
    jgroups.jar 用于支持Jboss集群底層通信
    jboss-cache-jdk50.jar 用于加載org.jboss.cache.aop.TreeCacheAop
          2.2 修改配置文件

    • 打開$JBOSS_HOME/server/default/deploy/jboss-web.deployer/server.xml,將 <Engine name="jboss.web" defaultHost="localhost"> 改為 <Engine name="jboss.web" defaultHost="localhost" jvmRoute="node1">. 其中jvmRoute是用來讓Apache服務器識別節點名稱的(名稱可以隨便起,只要跟下面的配置文件workers.properties中指定的節點名稱相同即可)。同理,更改另一臺服務器的server.xml文件(注意:節點名稱不能重復 

    • 打開$JBOSS_HOME/server/default/deploy/jboss-web.deployer/ROOT.war/WEB-INF/web.xml ,在<web-app>的末尾添加 <distributable/> 標記

    • 打開$JBOSS_HOME/server/default/deploy/jboss-web.deployer/META-INF/jboss-service.xml,把<attribute name="UseJK">false</attribute> 中false改為true. 這樣會采用粘性sesson策略,也即每個session都會由一臺特定的jboss 處理.

    • 配置Java Web應用項目。 在Java Web應用項目的WEB-INF文件夾內添加jboss-web.xml ,內容是:

     <?xml version="1.0" encoding="UTF-8"?> 
           <!DOCTYPE jboss-web PUBLIC  
                     "-//JBoss//DTD Web Application 4.2//EN"  
                     "http://www.jboss.org/j2ee/dtd/jboss-web_4_2.dtd"> 
           <jboss-web> 
                   <replication-config> 
                           <replication-trigger>SET_AND_NON_PRIMITIVE_GET</replication-trigger> 
                            <replication-granularity>SESSION</replication-granularity> 
                            <replication-field-batch-mode>true</replication-field-batch-mode> 
                    </replication-config> 
                    <context-root>/jspdemo</context-root>  <!-- 這里替換你的Java Web應用名 -->
    
           </jboss-web> 

    • 配置Apache服務器

                a) 打開$APACHE_HOME/conf/httpd.conf, 在末尾添加如下的配置:

    # 加載mod_jk.so 模塊
    LoadModule jk_module modules/mod_jk.so
    
    #
    # 配置 mod_jk.so模塊
    # 
    JkWorkersFile conf/workers.properties
    # 指定哪些請求交由jboss處理
    JkMountFile conf/uriworkermap.properties  
    # mod_jk插件的日志
    JkLogFile logs/mod_jk.log
    # mod_jk 的日志級別
    JkLogLevel warn
     

                 b) 建立$APACHE_HOME/conf/workers.properties文件,內容為:

    # Define list of workers that will be used
    # for mapping requests
    worker.list=loadbalancer,status
    # Define Node1
    # modify the host as your host IP or DNS name and your AJP 1.3 port
    worker.node1.port=6009
    worker.node1.host=127.0.0.1
    worker.node1.type=ajp13
    worker.node1.lbfactor=1
    worker.node1.socket_timeout=60
    worker.node1.connection_pool_timeout=60
    worker.node1.ping_mode=A
    worker.node1.ping_timeout=20000
    worker.node1.connect_timeout=20000
    
    # Define Node2
    # modify the host as your host IP or DNS name and your AJP 1.3 port
    worker.node2.port=7009
    worker.node2.host=127.0.0.1
    worker.node2.type=ajp13
    worker.node2.lbfactor=1
    worker.node2.socket_timeout=60
    worker.node2.connection_pool_timeout=60
    worker.node2.ping_mode=A
    worker.node2.ping_timeout=20000
    worker.node2.connect_timeout=20000
    
    # Load-balancing behaviour
    worker.loadbalancer.type=lb
    worker.loadbalancer.balance_workers=node1,node2
    worker.loadbalancer.sticky_session=true
    worker.loadbalancer.sticky_session_force=false
    
    # Status worker for managing load balancer
    worker.status.type=status

                c) 建立$APACHE_HOME/conf/uriworkermap.properties文件,內容為:

    # 這里表示所有的請求都交給負載均衡器(也就是mod_jk.so這個模塊)進行轉發
    /*=loadbalancer
    
    #你可以聲明對某些靜態資源的請求無需交給jboss處理. 這樣的話,你需要把這部分靜態資源(比如gif, jpg, css等文件)拷貝到
    # Apache服務器的部署目錄中
    #!/*.gif=loadbalancer
    #!/*.jpg=loadbalancer
    #!/*.png=loadbalancer
    #!/*.css=loadbalancer
    #!/*.js=loadbalancer
    #!/*.htm=loadbalancer
    #!/*.html=loadbalancer

                 d) 將mod_jk.so 拷貝到$APACHE_HOME/modules

     三、測試

           在兩臺Jboss服務器上部署一個相同的Java Web項目(比如通過session緩存記錄JSP頁面的訪問次數)。 啟動進Apache, Jboss進行測試

    原文地址:http://jianfeiok.iteye.com/blog/1161698

 本文由用戶 fmms 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!