`
suhuanzheng7784877
  • 浏览: 702648 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
Ff8d036b-05a9-33b5-828a-2633bb68b7e6
读金庸故事,品程序人生
浏览量:47712
社区版块
存档分类
最新评论

在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 
 修改下面代码:

<Engine name="jboss.web" defaultHost="localhost">

修改为:

<Engine name="jboss.web" defaultHost="localhost" jvmRoute="node1">

 其中 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<distributable/>

   完成后web.xml代码如下:

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

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

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

1Include conf/mod-jk.conf

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

 1# 定义request所要转发到的节点
 2worker.list=loadbalancer,status
 3# 定义节点 Node1
 4worker.node1.port=8009
 5worker.node1.host=192.168.0.2
 6worker.node1.type=ajp13
 7worker.node1.lbfactor=1
 8worker.node1.cachesize=10
 9# 定义节点 Node2
10worker.node2.port=8009
11worker.node2.host=192.168.0.3
12worker.node2.type=ajp13
13worker.node2.lbfactor=1
14worker.node2.cachesize=10
15# 负载配置
16worker.loadbalancer.type=lb
17worker.loadbalancer.balance_workers=node1,node2
18worker.loadbalancer.sticky_session=0
19worker.status.type=status

上述代码中:port是配置JBoss AJP所监听的端口号,可以在%JBoss_Home%\server\default\deploy\jbossweb-tomcat55.sar\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复制有影响),到这里所有的配置就全部完成啦^o^启动192.168.0.2上的apache和两台机器上的JBoss。
   打开浏览器,输入网址访问apache:http://192.168.0.2/test/index.jsp,回车!看到了吧?页面上有JBoss所在机器的IP地址,刷新页面还能看到IP在变化,说明apache将request分发到了不同的JBoss上,在输入框中输入随便一个字符串并提交还能测试JBoss 的session复制情况。

分享到:
评论

相关推荐

    快速配置JBoss集群

    通过以上步骤,即可快速地在default目录下配置好一个JBoss集群。需要注意的是,虽然搭建集群的过程相对简单,但在实际生产环境中还需要根据具体的业务需求对服务器进行进一步的优化以及实现更复杂的负载均衡策略。...

    在jboss上部署web应用

    - server/default/deploy目录:热部署目录,任何在此目录下的文件或目录都会被自动部署。 【目录详解】 - server/default/deploy目录:这个目录是JBoss的部署目录,可以放置EJB、WAR、EAR文件,甚至是自定义服务。...

    jboss集群部署详细资源

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

    jboss集群

    以上是JBoss集群的基本配置和原理,具体步骤可以参考提供的两个博客文章:“在default目录下快速配置JBoss集群(Web方面)”和“JBoss安装,集群配置,负载均衡和session复制配置”。这些资源提供了详细的步骤指南和...

    jboss集群配置方式及使用

    ### jboss集群配置方式及使用 #### JBoss简介与配置使用概述 JBoss是一套开源的应用服务器,由JBoss社区维护和支持。它提供了一个全面的企业级应用开发平台,支持多种应用部署模型,如Web应用程序、EJBs以及消息...

    jboss热部署配置

    2. **配置部署目录**:默认情况下,JBoss会监控`deploy`目录下的文件变化。如果希望使用其他目录,可以在`jboss-service.xml`中更改`deploymentDir`属性值。 3. **禁用模块的TOMCAT类加载器**:某些模块可能使用了...

    jboss的配置

    在`server/default/deploy`目录下,你可以找到如`jboss-service.xml`、`jboss-jdbc.xml`、`jboss-jndi.xml`等文件,它们分别对应服务、数据库连接和JNDI的配置。 JBoss的配置灵活性很高,但同时也需要一定的熟悉度...

    JBOSS负载均衡配置

    3. **配置Web应用**:在`E:\jboss-4.2.3.GA\server\default\deploy\jboss-web.deployer\ROOT.war\WEB-INF\web.xml`文件中添加`&lt;distributable/&gt;`标签来启用集群支持: ```xml &lt;web-app&gt; &lt;/web-app&gt; ``` 4. **...

    JBOSS4.2 基本配置(全)

    6. **其他高级配置**:除了以上基础配置,JBOSS还支持日志管理、事务管理、集群部署、JMX监控等多种功能,其配置文件分布在`server/default/conf`和`server/default/deploy`目录下。例如,`logging.properties`用于...

    JBoss5配置相机

    在`$JBOSS_HOME/server/default/conf/login-config.xml`中配置认证模块,`$JBOSS_HOME/server/default/conf/jboss-web.xml`中配置Web应用的安全域。 7. **集群配置** 如果需要在多台服务器上运行JBoss AS 5以实现...

    JBoss安装配置.doc

    2. **web服务端口**:若需更改web服务的默认端口号8080,需编辑server\default\deploy\jboss-web.deployer\server.xml文件,查找并修改8080相关的配置。 这只是JBoss安装配置的基本介绍,实际操作中可能需要根据...

    JBOSS5.0配置详解.docx

    此外,JBoss的配置还包括数据库连接、EJB配置、安全设置、集群配置等多个方面,这些都需要根据实际应用需求进行详细配置。例如,可以通过修改`server/default/conf/jboss-service.xml`来配置JMS服务,或者通过`...

    jboss安装配置指南

    例如,EJB 组件位于 $JBOSS_HOME/server/default/deploy 目录下,日志文件通常在 $JBOSS_HOME/server/default/log 中,配置文件则位于 $JBOSS_HOME/server/default/conf。 若需获取更多关于 JBoss 配置的详细信息,...

    JBoss安装配置.ppt

    本教程将详细介绍如何在Windows环境下安装和配置JBoss,并演示一个简单的Servlet应用程序的部署步骤。 **JBoss安装配置** 1. **安装Step 1** 首先,你需要下载并安装Java 2 Standard Edition JDK 5.0,可以从...

    jboss配置入门学习教程.doc

    在JBoss 3.2.6中,修改`.../deploy/jbossweb-tomcat50.sar/server.xml`,而在JBoss 3.2.3中,应在`.../default/deploy/jbossweb-tomcat41.sar/META-INF/jboss-service.xml`中配置。配置负载均衡时,可能需要调整与...

    JBoss安装配置[借鉴].pdf

    进入`server\default\deploy\jboss-web.deployer`目录,编辑`server.xml`文件,将8080端口替换为你选择的可用端口。 - 另外,启动失败可能是由于JDK安装不正确或JBoss下载不完整。请检查JDK的安装路径是否正确,并...

Global site tag (gtag.js) - Google Analytics