所需组件
Apache 2.2.22
mod_jk 1.2.3
JBOSS 5.1.0GA
安装步骤
安装Apache2.2.22
将mod_jk-1.2.30-httpd-2.2.3.so重命名为mod_jk.so,复制到%APACH_HOME%/modules
解压缩jboss 5.1.0.GA
配置
在%APACHE_HOME%\conf\http.conf文件中添加如下内容:
LoadModule jk_module modules/mod_jk.so
# Where to find workers.properties
JkWorkersFile conf/workers.properties
# where to find the log file
JkLogFile logs/mod_jk.log
# set the log level set the log level
JkLogLevel info
# map to the status server
JkMount /private/admin/mystatus mystatus
# router the request to the right host
JkMount /* balance
然后再%APACHE_HOME%\conf\下新建workers.properties文件,并添加如下内容:
# define list of workers that will be used
# for mapping requests
worker.list=balance,mystatus
# Define Node1
worker.node1.port=8009
worker.node1.host=xxx.xxx.xxx.xxx
worker.node1.type=ajp13
worker.node1.lbfactor=1
worker.node1.socket_timeout=30
worker.node1.socket_keepalive=1
# Define Node2
worker.node2.port=8009
worker.node2.host=yyy.yyy.yyy.yyy
worker.node2.type=ajp13
worker.node2.lbfactor=1
worker.node2.socket_timeout=30
worker.node2.socket_keepalive=1
# Load-balancing behaviour
worker.balance.type=lb
worker.balance.balance_workers=node1,node2
worker.balance.sticky_session=1
# Status worker for managing load balancer
worker.mystatus.type=status
以上内容用于配置mod_jk,使其监听两个servlet容器(如JBOSS实例)node1和node2。
在node1中,打开%JBOSS_HOME%/server/all/deploy/jbossweb.sar/server.xml,修改Engine节点:
同样,在node2中,将该文件的Engine节点改为:
JBOSS默认的session是共享的。
在部署Web应用时,需要在应用程序的web.xml中加入节点,如下所示:
Welcome to JBoss
Welcome to JBoss
启动
启动Apache
打开控制台,定位到%APACHE_HOME%,输入如下命令启动Apache服务器:
httpd.exe -k start
输入如下命令可以关闭Apache服务器:
httpd.exe -k shutdown
以集群方式启动JBOSS
以集群方式启动JBOSS的命令如下:
run -c all -g DocsPartition -u 239.255.100.100 -b 0.0.0.0 -Djboss.messaging.ServerPeerID=1
在集群的其他JBOSS实例上,要修改jboss.messaging.ServerPeerID所对应的值,该值要求在集群中是唯一的。
测试
新建一个test.war文件夹,在该文件夹下创建index.jsp文件和WEB-INF文件夹。在WEB-INF文件夹下创建如前面所示的web.xml文件。在index.jsp文件中加入如下内容:
Cluster App Test
This is responsed by
Host Name :
Time :
Server Info:
0) {
String dataValue = request.getParameter("dataValue");
session.setAttribute(dataName, dataValue);
}
out.print(" Session 列表");
Enumeration e = session.getAttributeNames();
while (e.hasMoreElements()) {
String name = (String)e.nextElement();
String value = session.getAttribute(name).toString();
out.println( name + " = " + value+"");
System.out.println( name + " = " + value);
}
%>
名称:
值:
将该文件夹复制到集群中所有JBOSS实例的%JBOSS_HOME%/server/all/deploy下,以集群方式重启所有JBOSS实例。
在浏览器中输入http://localhost:8080/test,观察结果。
参考资料
UsingMod_jk1.2WithJBoss
Testing Cluster Formation with JGroups
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com