首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 操作系统 >

在default目录上快速配置JBoss集群(Web方面) 转载

2012-08-21 
在default目录下快速配置JBoss集群(Web方面) 转载说起JBoss集群好像很高深的样子,其实一点也不恐怖,建立一

在default目录下快速配置JBoss集群(Web方面) 转载

说起JBoss集群好像很高深的样子,其实一点也不恐怖,建立一个集群很简单,难的是怎么针对具体的应用优化服务器和实现负载均衡(学习中^o^)。本文将带领大家在JBoss的default目录下建立一个简单的Web方面的JBoss集群。
搭建环境
两台电脑 //其实一台也够了,不过需要修改其中一个JBoss监听的端口,要不然有冲突
?jboss-4.0.4.GA
?apache_2.0.59 //我使用的是apache_2.0.59-win32-x86-no_ssl,其实无所谓的
?mod_jk-apache-2.0.59.so //Apache请求分发的模块,官网上可以找到
首先安装JBoss,我用的是zip格式的,直接解压缩就可以了,在两台电脑里分别安装。接下来在其中一台电脑上(这里是192.168.0.2)安装Apache(其实应该再找一台电脑来安装的),很简单,略过^o^(偶是不是很懒^o^)
配置JBoss
假设两台电脑的IP分别为192.168.0.2和192.168.0.3。我们这里使用JBoss的default目录。将如下文件从%JBoss_Home%\server\all\lib里面拷到%JBoss_Home%\server\default\lib目录下:
jbossha.jar(加载org.jboss.ha.framework.server.ClusterPartition)
jgroups.jar(JBoss集群底层通信协议)
?jboss-cache.jar(加载org.jboss.cache.aop.TreeCacheAop)
还要从%JBoss_Home%\server\all\deploy里把cluster-service.xml和tc5-cluster.sar拷贝到%JBoss_Home%\server\default\deploy里面。
编辑192.168.0.2的%JBoss_Home%\server\default\deploy\jbossweb-tomcat55.sar\server.xml?
?修改下面代码:

在default目录上快速配置JBoss集群(Web方面) 转载<Engine?name="jboss.web"?defaultHost="localhost">
在default目录上快速配置JBoss集群(Web方面) 转载

修改为:

在default目录上快速配置JBoss集群(Web方面) 转载<Engine?name="jboss.web"?defaultHost="localhost"?jvmRoute="node1">
在default目录上快速配置JBoss集群(Web方面) 转载

?其中 jvmRoute是用来让apache识别的节点名称,一个节点一个名称,注意不要有重复的(可以结合IP设置)。同理编辑192.168.0.3的%JBoss_Home%\server\default\deploy\jbossweb-tomcat55.sar\server.xml
注意把jvmRoute设置为node2,可以设置成别的只要和192.168.0.2的不重复就行,但是要和Apache的workers.properties(稍后介绍)下的配置一致。?在%JBoss_Home%\server\default\deploy\jbossweb-tomcat55.sar\ROOT.war\目录下添加一个新文件夹\test,并在里面添加如下3个jsp文件:
index.jsp

test_action.jsp

session.jsp

JSP代码略去………………

?编辑%JBoss_Home%\server\default\deploy\jbossweb-tomcat55.sar\ROOT.war\WEB-INF\web.xml在<web-app>节点下增加如下代码:

1在default目录上快速配置JBoss集群(Web方面) 转载<distributable/>

???完成后web.xml代码如下:

?1在default目录上快速配置JBoss集群(Web方面) 转载<?xml?version="1.0"?encoding="ISO-8859-1"?>
?2在default目录上快速配置JBoss集群(Web方面) 转载
?3在default目录上快速配置JBoss集群(Web方面) 转载<!DOCTYPE?web-app
?4在default目录上快速配置JBoss集群(Web方面) 转载????PUBLIC?"-//Sun?Microsystems,?Inc.//DTD?Web?Application?2.3//EN"
?5在default目录上快速配置JBoss集群(Web方面) 转载????"http://java.sun.com/dtd/web-app_2_3.dtd">
?6在default目录上快速配置JBoss集群(Web方面) 转载
?7在default目录上快速配置JBoss集群(Web方面) 转载<web-app>
?8在default目录上快速配置JBoss集群(Web方面) 转载??<distributable/>
?9在default目录上快速配置JBoss集群(Web方面) 转载??<display-name>Welcome?to?JBoss</display-name>
10在default目录上快速配置JBoss集群(Web方面) 转载??<description>
11在default目录上快速配置JBoss集群(Web方面) 转载?????Welcome?to?JBoss
12在default目录上快速配置JBoss集群(Web方面) 转载??</description>
13在default目录上快速配置JBoss集群(Web方面) 转载??<servlet>
14在default目录上快速配置JBoss集群(Web方面) 转载????<servlet-name>Status?Servlet</servlet-name>
15在default目录上快速配置JBoss集群(Web方面) 转载????<servlet-class>org.jboss.web.tomcat.tc5.StatusServlet</servlet-class>
16在default目录上快速配置JBoss集群(Web方面) 转载??</servlet>
17在default目录上快速配置JBoss集群(Web方面) 转载??<servlet-mapping>
18在default目录上快速配置JBoss集群(Web方面) 转载????<servlet-name>Status?Servlet</servlet-name>
19在default目录上快速配置JBoss集群(Web方面) 转载????<url-pattern>/status</url-pattern>
20在default目录上快速配置JBoss集群(Web方面) 转载??</servlet-mapping>
21在default目录上快速配置JBoss集群(Web方面) 转载</web-app>
22在default目录上快速配置JBoss集群(Web方面) 转载

???看到第8行了吗?^o^到这里JBoss就配置完成了^o^
??????配置Apache
???JBoss的Web集群使用apache的mod_jk,浏览器请求apache服务器,apache服务器根据workers.properties中的配置进行request分发,apache服务器和Jboss中的Tomcat可以用ajp1.3进行通信的,request通过ajp1.3协议的包装被发送到Jboss,Jboss执行后返回结果。将下载到的mod_jk-apache-2.0.59.so保存到%Apache%\modules\目录下,并去掉版本号重命名为“mod_jk.so”,如果不改也可以在mod-jk.conf文件(稍后介绍)里修改配置。在%Apache%\conf\目录下新建mod-jk.conf,并将如下代码添加进去:

?1在default目录上快速配置JBoss集群(Web方面) 转载#?Load?mod_jk?module
?2在default目录上快速配置JBoss集群(Web方面) 转载#?Specify?the?filename?of?the?mod_jk?lib
?3在default目录上快速配置JBoss集群(Web方面) 转载LoadModule?jk_module?modules/mod_jk.so
?4在default目录上快速配置JBoss集群(Web方面) 转载#?Where?to?find?workers.properties
?5在default目录上快速配置JBoss集群(Web方面) 转载JkWorkersFile?conf/workers.properties
?6在default目录上快速配置JBoss集群(Web方面) 转载#?Where?to?put?jk?logs
?7在default目录上快速配置JBoss集群(Web方面) 转载JkLogFile?logs/mod_jk.log
?8在default目录上快速配置JBoss集群(Web方面) 转载#?Set?the?jk?log?level?[debug/error/info]
?9在default目录上快速配置JBoss集群(Web方面) 转载JkLogLevel?debug
10在default目录上快速配置JBoss集群(Web方面) 转载#?Select?the?log?format
11在default目录上快速配置JBoss集群(Web方面) 转载JkLogStampFormat?"[%a?%b?%d?%H:%M:%S?%Y]"
12在default目录上快速配置JBoss集群(Web方面) 转载#?JkOptions?indicates?to?send?SSK?KEY?SIZE
13在default目录上快速配置JBoss集群(Web方面) 转载JkOptions?+ForwardKeySize?+ForwardURICompat?-ForwardDirectories
14在default目录上快速配置JBoss集群(Web方面) 转载#?JkRequestLogFormat
15在default目录上快速配置JBoss集群(Web方面) 转载JkRequestLogFormat?"%w?%V?%T"
16在default目录上快速配置JBoss集群(Web方面) 转载#?Mount?your?applications
17在default目录上快速配置JBoss集群(Web方面) 转载#JkMount?/application/*?loadbalancer
18在default目录上快速配置JBoss集群(Web方面) 转载JkMount?/*?loadbalancer
19在default目录上快速配置JBoss集群(Web方面) 转载#?You?can?use?external?file?for?mount?points.
20在default目录上快速配置JBoss集群(Web方面) 转载#?It?will?be?checked?for?updates?each?60?seconds.
21在default目录上快速配置JBoss集群(Web方面) 转载#?The?format?of?the?file?is:?/url=worker
22在default目录上快速配置JBoss集群(Web方面) 转载#?/examples/*=loadbalancer
23在default目录上快速配置JBoss集群(Web方面) 转载JkMountFile?conf/uriworkermap.properties
24在default目录上快速配置JBoss集群(Web方面) 转载#?Add?shared?memory.
25在default目录上快速配置JBoss集群(Web方面) 转载#?This?directive?is?present?with?1.2.10?and
26在default目录上快速配置JBoss集群(Web方面) 转载#?later?versions?of?mod_jk,?and?is?needed?for
27在default目录上快速配置JBoss集群(Web方面) 转载#?for?load?balancing?to?work?properly
28在default目录上快速配置JBoss集群(Web方面) 转载JkShmFile?logs/jk.shm
29在default目录上快速配置JBoss集群(Web方面) 转载#?Add?jkstatus?for?managing?runtime?data
30在default目录上快速配置JBoss集群(Web方面) 转载<Location?/jkstatus/>
31在default目录上快速配置JBoss集群(Web方面) 转载JkMount?status
32在default目录上快速配置JBoss集群(Web方面) 转载Order?deny,allow
33在default目录上快速配置JBoss集群(Web方面) 转载Deny?from?all
34在default目录上快速配置JBoss集群(Web方面) 转载Allow?from?127.0.0.1
35在default目录上快速配置JBoss集群(Web方面) 转载</Location>

?上述代码的第3行就是配置mod_jk.so模块的路径。编辑%Apache%\conf\httpd.conf在最后一行添加如下代码:

1在default目录上快速配置JBoss集群(Web方面) 转载Include?conf/mod-jk.conf

在?%Apache%\conf\目录下添加workers.properties文件,该文件就是配置Apache所要将request转发到的JBoss的路径信息,代码如下:

?1在default目录上快速配置JBoss集群(Web方面) 转载#?定义request所要转发到的节点
?2在default目录上快速配置JBoss集群(Web方面) 转载worker.list=loadbalancer,status
?3在default目录上快速配置JBoss集群(Web方面) 转载#?定义节点?Node1
?4在default目录上快速配置JBoss集群(Web方面) 转载worker.node1.port=8009
?5在default目录上快速配置JBoss集群(Web方面) 转载worker.node1.host=192.168.0.2
?6在default目录上快速配置JBoss集群(Web方面) 转载worker.node1.type=ajp13
?7在default目录上快速配置JBoss集群(Web方面) 转载worker.node1.lbfactor=1
?8在default目录上快速配置JBoss集群(Web方面) 转载worker.node1.cachesize=10
?9在default目录上快速配置JBoss集群(Web方面) 转载#?定义节点?Node2
10在default目录上快速配置JBoss集群(Web方面) 转载worker.node2.port=8009
11在default目录上快速配置JBoss集群(Web方面) 转载worker.node2.host=192.168.0.3
12在default目录上快速配置JBoss集群(Web方面) 转载worker.node2.type=ajp13
13在default目录上快速配置JBoss集群(Web方面) 转载worker.node2.lbfactor=1
14在default目录上快速配置JBoss集群(Web方面) 转载worker.node2.cachesize=10
15在default目录上快速配置JBoss集群(Web方面) 转载#?负载配置
16在default目录上快速配置JBoss集群(Web方面) 转载worker.loadbalancer.type=lb
17在default目录上快速配置JBoss集群(Web方面) 转载worker.loadbalancer.balance_workers=node1,node2
18在default目录上快速配置JBoss集群(Web方面) 转载worker.loadbalancer.sticky_session=0
19在default目录上快速配置JBoss集群(Web方面) 转载worker.status.type=status

上述代码中:port是配置JBoss AJP所监听的端口号,可以在%JBoss_Home%\server\default\deploy\jbossweb-tomcat55.sar\server.xml?看到,如下

1在default目录上快速配置JBoss集群(Web方面) 转载<!--?A?AJP?1.3?Connector?on?port?8009?-->
2在default目录上快速配置JBoss集群(Web方面) 转载<Connector?port="8009"?address="${jboss.bind.address}"?
3在default目录上快速配置JBoss集群(Web方面) 转载?????????emptySessionPath="true"?enableLookups="false"
4在default目录上快速配置JBoss集群(Web方面) 转载?????????redirectPort="8443"?protocol="AJP/1.3"/>

???host定义JBoss所在机器的IP地址
???lbfactor定义该节点的权重,数字越大分发到该节点的request越多,cachesize是servlet线程池的大小(对session复制有影响),到这里所有的配置就全部完成啦^o^启动192.168.0.2上的apache和两台机器上的JBoss。
???打开浏览器,输入网址访问apache:http://192.168.0.2/test/index.jsp,回车!看到了吧?页面上有JBoss所在机器的IP地址,刷新页面还能看到IP在变化,说明apache将request分发到了不同的JBoss上,在输入框中输入随便一个字符串并提交还能测试JBoss 的session复制情况。

热点排行