LinuxEye - Linux系统教程

LinuxEye - Linux系统教程

当前位置: 主页 > Linux配置 >

Jboss 4.2.3 集群配置方法

时间:2012-06-02 10:50来源:ITeye 编辑:admin 点击:
一、准备工作 安装JDK 1.5或以上版本,Jboss 4.2.3,apache 2.2.x, mod_jk.so 配置JAVA_HOME, JBOSS_HOME,APACHE_HOME环境变量 其中 mod_jk是apache服务器连接Jboss的插件 二、配置 假设有两台服务器都安装了

一、准备工作

  • 安装JDK 1.5或以上版本,Jboss 4.2.3,apache 2.2.x, mod_jk.so
  • 配置JAVA_HOME, JBOSS_HOME,APACHE_HOME环境变量
其中 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

三、测试

       在两台Jboss服务器上部署一个相同的Java Web项目(比如通过session缓存记录JSP页面的访问次数)。 启动进Apache, Jboss进行测试

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

转载请保留固定链接: https://linuxeye.com/configuration/528.html

------分隔线----------------------------
标签:Jboss 4.2.3集群
栏目列表
推荐内容