`

jboss下集群

阅读更多
在网上看到一位网友的文章,讲述其配置过程,逐步做下来,就完成了配置,为了以后查询方便,自己也把实现的步骤记录下来了。:)



软件环境:

jboss-4.2.2.GA

apache_2.0.59-win32-x86-no_ssl.msi

mod_jk-apache-2.0.59.so

Jdk1.6





配置过程:



2.1 JBoss安装
在两台电脑上分别将JBoss-4.2.2GA.zip文件解压到要安装的位置即可。不需要其他设置。假设两台电脑的IP分别为192.168.0.9,192.168.0.71
2.2 Apache安装
将Apache安装软件apache_2.0.59-win32-x86-no_ssl.msi在一台服务器上,双击安装。本文安装在192.168.0.9的那台电脑上。
3 配置过程
3.1 配置JBoss
分别在两台服务器将如下文件从%JBoss_Home%\server\all\lib里面拷到%JBoss_Home%\server\default\lib目录下:
jbossha.jar(加载org.jboss.ha.framework.server.ClusterPartition)
jgroups.jar(JBoss集群底层通信协议)
jboss-cache-jdk50.jar (加载org.jboss.cache.aop.TreeCacheAop)

再从%JBoss_Home%\server\all\deploy里把cluster-service.xml和jboss-web-cluster.sar
拷贝到%JBoss_Home%\server\default\deploy里面。
编辑192.168.0.71的%JBoss_Home%\server\default\deploy\ jboss-web.deployer\server.xml
   修改下面代码:
<Engine name="jboss.web" defaultHost="localhost">
   修改为:
<Engine name="jboss.web" defaultHost="localhost" jvmRoute="node2">
其中 jvmRoute是用来让apache识别的节点名称,一个节点一个名称,注意不要有重复的(可以结合IP设置)。
同理编辑192.168.0.9的%JBoss_Home%\server\default\deploy\ jboss-web.deployer\server.xml文件,注意把jvmRoute设置为node1,可以设置成别的只要和192.168.0.71的不重复就行,但是要和Apache的workers.properties(稍后介绍)下的配置一致。

  编辑%JBoss_Home%\server\default\deploy\jboss-web.deployer\ROOT.war\WEB-INF\web.xml在<web-app>节点下增加如下代码:
<distributable/>
完成后的web.xml文件内容如下:
<?xml version="1.0" encoding="ISO-8859-1"?>

<!DOCTYPE web-app
    PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
    "http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
<distributable/>
  <display-name>Welcome to JBoss</display-name>
  <description>
     Welcome to JBoss
  </description>
  <servlet>
    <servlet-name>Status Servlet</servlet-name>
    <servlet-class>org.jboss.web.tomcat.service.StatusServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>Status Servlet</servlet-name>
    <url-pattern>/status</url-pattern>
  </servlet-mapping>
</web-app>

3.2 配置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保存到192.168.0.9那台服务器的%Apache%\modules\目录下,并去掉版本号重命名为“mod_jk.so”,
在%Apache%\conf\目录下新建mod-jk.conf,并将如下代码添加进去:
# Load mod_jk module
# Specify the filename of the mod_jk lib
LoadModule jk_module modules/mod_jk.so
# Where to find workers.properties
JkWorkersFile conf/workers.properties
# Where to put jk logs
JkLogFile logs/mod_jk.log
# Set the jk log level [debug/error/info]
JkLogLevel debug
# Select the log format
JkLogStampFormat "[%a %b %d %H:%M:%S %Y]"
# JkOptions indicates to send SSK KEY SIZE
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
# JkRequestLogFormat
JkRequestLogFormat "%w %V %T"
# Mount your applications
#JkMount /application/* loadbalancer
JkMount /* loadbalancer
# You can use external file for mount points.
# It will be checked for updates each 60 seconds.
# The format of the file is: /url=worker
# /examples/*=loadbalancer
JkMountFile conf/uriworkermap.properties
# Add shared memory.
# This directive is present with 1.2.10 and
# later versions of mod_jk, and is needed for
# for load balancing to work properly
JkShmFile logs/jk.shm
# Add jkstatus for managing runtime data
<Location /jkstatus/>
JkMount status
Order deny,allow
Deny from all
Allow from 127.0.0.1
</Location>

上述代码的第3行就是配置mod_jk.so模块的路径。

在 %Apache%\conf\目录下添加workers.properties文件,该文件就是配置Apache所要将request转发到的JBoss的路径信息,代码如下:
#
worker.list=loadbalancer,status
#  Node1
worker.node1.port=8009
worker.node1.host=192.168.0.9
worker.node1.type=ajp13
worker.node1.lbfactor=1
worker.node1.cachesize=10
#  Node2
worker.node2.port=8009
worker.node2.host=192.168.0.71
worker.node2.type=ajp13
worker.node2.lbfactor=1
worker.node2.cachesize=10
#
worker.loadbalancer.type=lb
worker.loadbalancer.balance_workers=node1,node2
worker.loadbalancer.sticky_session=0
worker.status.type=status
上述代码中:
   port是配置JBoss AJP所监听的端口号,可以在%JBoss_Home%\server\default\deploy\jboss-web.deployer \server.xml 看到,如下
1<!-- A AJP 1.3 Connector on port 8009 -->
2<Connector port="8009" address="${jboss.bind.address}"
3         emptySessionPath="true" enableLookups="false"
4         redirectPort="8443" protocol="AJP/1.3"/>    host定义JBoss所在机器的IP地址
lbfactor定义该节点的权重,数字越大分发到该节点的request越多
cachesize是servlet线程池的大小(对session复制有影响)
4 测试
在%JBoss_Home%\server\default\deploy\jboss-web.deployer\ROOT.war\目录下添加一个新文件夹\test,并在里面添加如下3个jsp文件:
index.jsp:
<%@ page contentType="text/html;charset=ISO8859_1" %>

<html>
<head>
<title>Test</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body onload="document.form.name.focus()">
<br><br><br>
<center>
The host is : <%=java.net.InetAddress.getLocalHost().toString()%><br>
Your session id is : <%=session.getId()%><br>
Your session detail is : <%=session.toString()%><br>
Your session context is : <%=session.getSessionContext()%><br><br>
Please input your name:<br>
<form action="test_action.jsp" method="POST" name="form">
    <input type="input" name="name"/>
    <input type="submit" value="submit">
</form>
</center>
</body>
</html>

test_action.jsp:

<%@ page contentType="text/html;charset=ISO8859_1" %>

<html>
<head>
<title>Test Action</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<%
    String name = request.getParameter("name");
    session.setAttribute("name",name);
   String host = java.net.InetAddress.getLocalHost().toString();
%>
<body>
<br>
<br>
<center>
The host is : <%=host%><br><br>
Your session id is : <%=session.getId()%><br>
Your session detail is : <%=session.toString()%><br>
Your session context is : <%=session.getSessionContext()%><br><br>
Your name is : <%=name%><br>
This name is set into the session.<br>
Please click <a href="session.jsp">here</a> to check the session valid or not.
</center>
</body>
</html>

session.jsp:
<%@ page contentType="text/html;charset=ISO8859_1" %>

<html>
<head>
<title>Test Action</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<%
     String name = null;
    if(session.getAttribute("name")!=null)
        name = (String)session.getAttribute("name");
    String host = java.net.InetAddress.getLocalHost().toString();
%>
<body>
<br>
<br>
<center>
The host is : <%=host%><br>
Your session id is : <%=session.getId()%><br>
Your session detail is : <%=session.toString()%><br>
Your session context is : <%=session.getSessionContext()%><br><br>
<%
    if(name!=null){
        out.print("Your name is "+name+"<br>");
        out.print("The session is valid.");
    }
    else{
        out.print("The session is invalid!!!");
    }
%>
<a href="index.jsp">Return!</a>
</center>
</body>
<%
    if(session.getAttribute("name")!=null)
        session.invalidate();
%>
</html>
启动192.168.0.9上的apache和两台机器上的JBoss。
打开浏览器,输入网址访问apache:http://192.168.0.9/test/index.jsp,回车!可以看到
页面上有JBoss所在机器的IP地址,刷新页面还能看到IP在变化,说明apache将request分发到了不同的JBoss上,在输入框中输入随便一个字符串并提交还能测试JBoss 的session复制情况。




本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/nmgfire007/archive/2008/08/08/2788273.aspx

分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Apache2.2+JBOSS 5 集群配置

    1. **JBoss集群架构**: JBoss 集群可以采用两种架构:客户端拦截器(Client-side interceptor)和负载均衡器(Load balancer)。对于B/S结构的应用,通常采用负载均衡器架构。它由一个全局唯一的负载均衡器和多个...

    jboss7集群配置方案说明书

    在该模式下,JBoss7被设置为主从服务器结构,Apache则作为负载均衡器。主从服务器的配置关键在于`host.xml`文件的改动。在主服务器上,需要将`host.xml`中的IP地址更改为服务器实际IP,确保服务可以被正确识别。从...

    jboss集群完整介绍

    ### jboss集群完整介绍 #### 一、JBoss集群概览 JBoss集群是指一系列的计算机节点协同工作,为用户提供统一的网络资源服务。理想状态下,集群对外表现为一个整体,用户仅通过单一入口访问,无需知晓集群内部的具体...

    apache+jboss集群参考

    apache+jboss集群参考,参考介绍集群实现办法

    windows jboss 集群2

    【标题】:Windows环境下JBoss集群配置详解 在IT行业中,服务器集群是一种常见的高可用性和负载均衡解决方案。本文将深入探讨如何在Windows操作系统上配置JBoss应用服务器的集群环境,帮助开发者和系统管理员更好地...

    jboss 4.0.2 集群 配置

    这个是转载Bromon原创的重量级:jboss 4.0.2 集群 配置

    jboss5.1集群操作说明 apache2.2.4

    JBoss 5.1 是一个基于 Java 的应用服务器,提供了高度可扩展性和高可用性,支持集群部署。集群操作能够使多个 ...提供的压缩包文件 "jboss集群" 可能包含了示例配置文件或教程,可以帮助你更好地理解和实践这些概念。

    Linux JBoss EAP集群搭建

    通过上述步骤,可以在Linux环境下成功搭建JBoss EAP集群。domain模式不仅简化了运维工作,还提高了系统的可靠性和性能。此外,通过mod_cluster的支持,还可以实现更高级别的负载均衡和故障恢复机制。 总之,在构建...

    jboss集群部署详细资源

    本文将详细介绍如何在Apache和JBoss环境下搭建一个简单的集群。 首先,我们要明确集群的基本概念。集群是指多个独立的服务器节点,通过网络连接并协同工作,对外表现为单一的系统。在Apache和JBoss的集群环境中,...

    JBOSS的集群策略分析.doc

    【JBoss集群策略详解】 JBoss是一个开源的J2EE应用服务器,遵循J2EE规范,提供了包括集群在内的多种企业级功能。集群是JBoss的一大亮点,它弥补了J2EE标准未涵盖的企业级特性。本文主要关注JBoss的集群策略,特别是...

    JBoss4.2.0官方集群文档

    - **JBoss 配置:** JBoss 需要配置相应的集群 JNDI 服务,以支持集群环境下的 JNDI 操作。 #### 六、集群会话 EJB **会话 EJB:** 会话 Enterprise JavaBeans (EJB) 是一种用于构建分布式应用程序的组件模型。在...

    linux-jboss-eap 集群搭建

    在Linux环境下,搭建JBoss Enterprise Application Platform (EAP)的集群能够提高应用程序的可用性和可扩展性。JBoss EAP 6.4.0提供了两种运行模式:standalone(独立运行模式)和domain(域模式)。standalone模式...

    JBoss422集群配置指南(02)

    【JBoss4.2.2集群配置指南(02)】是针对JBoss应用服务器4.2.2版本的一个深入教程,旨在帮助初学者理解和掌握如何配置JBoss以实现高可用性和性能优化的企业级集群环境。这篇指南的核心内容涵盖了以下几个关键知识点: ...

    JBOSS7集群配置说明.doc

    【JBoss7集群配置详解】 JBoss7是一个流行的开源应用服务器,它提供了两种运行模式:独立模式(standalone)和域模式(domain)。独立模式适合简单的单服务器部署,而域模式则更适合大型分布式项目的部署,因为它...

    JBoss422集群配置指南(01)

    JBoss集群可以实现负载均衡、故障转移和资源共享,提高系统的容错性和可伸缩性。 2. 优势: - 负载均衡:通过分散请求到不同的节点,避免单一服务器过载。 - 高可用性:当某个节点失效时,其他节点可以接管其工作...

    CentOS下apache负载均衡与JBoss集群配置

    在本文中,我们将讨论在CentOS操作系统环境下,如何进行Apache负载均衡与JBoss集群的配置。负载均衡和集群配置是提高网站可用性、扩展性和性能的关键技术。通过这篇文章,我们会了解到详细的配置步骤,以及它们在...

    jboss集群指南配套源代码

    《JBoss集群指南》这本书深入浅出地介绍了如何配置和管理JBoss应用服务器的集群环境,以实现高可用性和负载均衡。源代码是作者在实践中调试并验证过的,旨在帮助读者更好地理解和应用书中所讲的知识点。以下是这些源...

Global site tag (gtag.js) - Google Analytics