记录日常工作关于系统运维,虚拟化云计算,数据库,网络安全等各方面问题。
 
0

Jboss 4.2.3 集群配置方法



一、准备工作

•安装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,将 改为 . 其中jvmRoute是用来让Apache服务器识别节点名称的(名称可以随便起,只要跟下面的配置文件workers.properties中指定的节点名称相同即可)。同理,更改另一台服务器的server.xml文件(注意:节点名称不能重复 。

•打开$JBOSS_HOME/server/default/deploy/jboss-web.deployer/ROOT.war/WEB-INF/web.xml ,在的末尾添加 标记. 注:可以只针对需要做集群的web应用做配置, 这里是全局生效的.

•打开$JBOSS_HOME/server/default/deploy/jboss-web.deployer/META-INF/jboss-service.xml,把false 中false改为true. 这样会采用粘性sesson策略,也即每个session都会由一台特定的jboss 处理.

•配置Java Web应用项目。 在Java Web应用项目的WEB-INF文件夹内添加jboss-web.xml ,内容是:

view sourceprint?
01

02

03 "-//JBoss//DTD Web Application 4.2//EN"

04 "http://www.jboss.org/j2ee/dtd/jboss-web_4_2.dtd">

05

06

07 SET_AND_NON_PRIMITIVE_GET

08 SESSION

09 true

10

11 /jspdemo

12

•配置Apache服务器

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

view sourceprint?
01 # 加载mod_jk.so 模块

02 LoadModule jk_module modules/mod_jk.so

03

04 #

05 # 配置 mod_jk.so模块

06 #

07 JkWorkersFile conf/workers.properties

08 # 指定哪些请求交由jboss处理

09 JkMountFile conf/uriworkermap.properties

10 # mod_jk插件的日志

11 JkLogFile logs/mod_jk.log

12 # mod_jk 的日志级别

13 JkLogLevel warn

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

view sourceprint?
01 # Define list of workers that will be used

02 # for mapping requests

03 worker.list=loadbalancer,status

04 # Define Node1

05 # modify the host as your host IP or DNS name and your AJP 1.3 port

06 worker.node1.port=6009

07 worker.node1.host=127.0.0.1

08 worker.node1.type=ajp13

09 worker.node1.lbfactor=1

10 worker.node1.socket_timeout=60

11 worker.node1.connection_pool_timeout=60

12 worker.node1.ping_mode=A

13 worker.node1.ping_timeout=20000

14 worker.node1.connect_timeout=20000

15

16 # Define Node2

17 # modify the host as your host IP or DNS name and your AJP 1.3 port

18 worker.node2.port=7009

19 worker.node2.host=127.0.0.1

20 worker.node2.type=ajp13

21 worker.node2.lbfactor=1

22 worker.node2.socket_timeout=60

23 worker.node2.connection_pool_timeout=60

24 worker.node2.ping_mode=A

25 worker.node2.ping_timeout=20000

26 worker.node2.connect_timeout=20000

27

28 # Load-balancing behaviour

29 worker.loadbalancer.type=lb

30 worker.loadbalancer.balance_workers=node1,node2

31 worker.loadbalancer.sticky_session=true

32 worker.loadbalancer.sticky_session_force=false

33

34 # Status worker for managing load balancer

35 worker.status.type=status

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

view sourceprint?01 # 这里表示所有的请求都交给负载均衡器(也就是mod_jk.so这个模块)进行转发

02 /*=loadbalancer

03

04 #你可以声明对某些静态资源的请求无需交给jboss处理. 这样的话,你需要把这部分静态资源(比如gif, jpg, css等文件)拷贝到

05 # Apache服务器的部署目录中

06 #!/*.gif=loadbalancer

07 #!/*.jpg=loadbalancer

08 #!/*.png=loadbalancer

09 #!/*.css=loadbalancer

10 #!/*.js=loadbalancer

11 #!/*.htm=loadbalancer

12 #!/*.html=loadbalancer

d) 将mod_jk.so 拷贝到$APACHE_HOME/modules

三、测试

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




转载请标明出处【Jboss 4.2.3 集群配置方法】。

《www.micoder.cc》 虚拟化云计算,系统运维,安全技术服务.

网站已经关闭评论