一、准备工作
其中 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,2.2 修改配置文件
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 |