jboss服务器配置多实例
jboss配置多实例的重要性
在开发, 测试项目的过程中, 我们经常需要在同一台主机上, 同一个服务器上配置多个运行实例。这样做有一下几点好处:
- 在项目开发, 调试阶段能最大限度的节省资源
- 某个实例出现异常或错误都不会对其他实例的运行造成影响
- 需要对某个实例进行重启、关闭等操作属于独立操作, 不会对服务器的运行造成影响
对重要性的介绍就到这里, 对jboss服务器进一步了解可以点击这里
本文地址: http://www.cnblogs.com/blackmanba/p/3674301.html或者http://forkme.info/run-jbosses/, 转载请注明源地址。
jboss server配置
解决这个问题的关键其实就是对于不同的实例分配不同的端口。
在linux下, 进入到jboss的server目录下, 拷贝一份实例数据修改项目名, 如图:

在jboss启动时默认发布的不同实例需要使用不同的端口监听。项目复制过来后由于端口一样所以会导致端口冲突, 无法启动。解决这个问题最简单的方法就是直接在配置文件中修改端口。这种方法当然可以, 但是对于jboss服务器来说, 每个实例所需的端口数非常多, 包括http协议的8080、AJP协议的8009、JNP服务的1099、RMI命名服务的1098等等, 并且这些端口配置都分布在不同的文件, 手工修改极易出错。
考虑到这些因素, jboss服务器提供了Binding-Manager服务, 不用繁琐的配置就能够实现多实例运行而端口不冲突。步骤如下:
1. 部署环境
以jboss 4.2.3 GA 为例, server下有两个不同的实例node1, node2(名字自定义), %JBOSS_HOME%表示jboss安装目录。
关键文件是%JBOSS_HOME%/docs/examples/binding-manager/sample-bindings.xml, 该文件默认情况下定义了4组不同的端口配置(分别是ports-default、ports-01、ports-02、ports-03), 也就是说默认情况下jboss支持部署4个不同的jboss实例。
2. node2配置
进入node2目录, 修改node2/conf/jboss-service.xml文件, 配置如下:
<mbean code="org.jboss.services.binding.ServiceBindingManager" name="jboss.system:service=ServiceBindingManager">
<attribute name="ServerName">ports-01</attribute>
<attribute name="StoreURL">${jboss.home.url}/docs/examples/binding-manager/sample-bindings.xml</attribute>
<attribute name="StoreFactoryClassName">
org.jboss.services.binding.XMLServicesStoreFactory
</attribute>
</mbean>
这里node2配置为使用ports-01的配置。
3. node1配置
node1默认可以不用配置, 这种情况下使用的是jboss提供的默认端口8080, 8009等, 也可以参照第一步的配置, 只需修改"ServerName"与node2不一样即可。ps: 只能是定义的四组端口范围内。
4. 自定义端口
这一步不是必须的, 上一步配置的时候已经指定了运行端口。如果你想修改实例http服务监听端口, 才需进行下列步骤。
进入node1目录, 修改node1/deploy/jboss-web.deployer/server.xml, 配置如下:
<Connector port="80" address="0.0.0.0"
maxThreads="250" maxHttpHeaderSize="8192"
emptySessionPath="true" protocol="HTTP/1.1"
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" />
里面port="80"选项可以修改为任意的端口, 只要不冲突即可。ps: node2的配置也与node1一致。
5. 启动实例
完成上述配置后, 实例的启动非常简单。如下:
%JBOSS_HOME%/bin/run.sh -c node1 -b ip地址 &
%JBOSS_HOME%/bin/run.sh -c node2 -b ip地址 &
ip地址指的就是项目的地址。
配置说明
如果没有指定运行端口而采用默认定义的4组端口配置, 端口是以以下方式进行设定的:
http服务端口默认情况下是8080, 其他实例的端口依次在8080的基础上增加100, 对应关系如下:
ports-default 8080
ports-01 8180
ports-02 8280
ports-03 8380
其他端口规律和http端口规律一致。eg: AJP端口依次为8009、8109、8209、8309。
注意事项
- 上述方法同样适用于同一台机器上面部署多个jboss而不是同一个jboss下部署多个实例
- 如果定义的4组端口不够用, 也可以自行添加其他port组
- 在正式环境下, 推荐将不同的实例绑定在不同的ip地址上
使用情景
- 32位JVM限制无法使用超过2G的内存, 通过多实例可以充分利用服务器上的大内存(不理解, 有懂的人请告知)
- 不同的jboss用于不同的用途, 比如开发环境, 测试环境的分离
- 在同一台机器上使用不同版本的jboss服务器
- 在同一台机器上部署基于不同JVM的jboss
jboss服务器配置多实例的更多相关文章
- Jboss Jmx-Console和 Jboss web-console安全设置
1.介绍 如果你暴露你的JBoss服务器通过网络(如通过启动服务器使用选项B 0.0.0.0或者通过改变jboss.bind.address首次出现0.0.0.0在.../jboss/server/d ...
- WebLogic Server 12c相对JBoss EAP 6的优势
原文来自:https://blogs.oracle.com/middlewareplace/entry/why_should_you_choose_oracle 1.多数据中心部署和集群 WebLog ...
- JBoss AS 7之初步了解(The Return Of The King)
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvam9obl9mX2xhdQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- 最近学习工作流 推荐一个activiti 的教程文档
全文地址:http://www.mossle.com/docs/activiti/ Activiti 5.15 用户手册 Table of Contents 1. 简介 协议 下载 源码 必要的软件 ...
- SQL Server-语句类别、数据库范式、系统数据库组成(一)
前言 终于等到这一天,我要开始重新系统学习数据库了,关于数据库这块,不出意外的话,每天会定时更新一篇且内容不会包含太多,简短的内容,深入的理解,Always to review the basics. ...
- java complier compliance level问题引发的思考
http://blog.csdn.net/shan9liang/article/details/17266519 ******************************************* ...
- Microsoft SqlServer2008技术内幕:T-Sql语言基础-读书笔记1
一.理论背景:关系模型,其数学理论是集合论和谓词逻辑. 1.集合论:集合定义是把我们直观或思维中确定的,相互间有明确区别的那些对象视为一个整体,这个整体就是集合. 2.谓词逻辑:谓词是判断对象是否有某 ...
- T-SQL :SQL Server系统数据库(二)
master:master数据库储存实例范围的元数据信息,服务器配置,实例中的所有数据库信息和初始化信息. Resource:Resource数据库是一个隐藏,只读数据库,存储所有系统对象的定义.当查 ...
- shiro实战系列(一)之入门实战
一.什么是shiro? Apache Shiro 是一个强大而灵活的开源安全框架,它干净利落地处理身份认证,授权,企业会话管理和加密. Apache Shiro 的首要目标是易于使用和理解.安全有 ...
随机推荐
- 基于webpivottable做的透视表
1.绑定数据和配置: var wptConfig=<%= wptConfig%>; webPivotTable.setCsvData(<%=dataFields %>, < ...
- CF 2013-2014CTS01E04(Killer Challenge-将质因数存在 进行Bitmask)
首先,把P进行质因数分解,每一个不用的质因数压成1位 f[i][j]表示1前i位用j“拥有”的质因数表示. 然后都懂得... #include<cstdio> #include<cs ...
- svn服务器及客户端安装使用
一.服务器安装: 1.yum install subversion 2.输入rpm -ql subversion查看安装位置,如下图: 我们知道svn在bin目录下生成了几个二进制文件. 输入 ...
- Java中获取完整的url
Java中获得完整的URl字符串 HttpServletRequest httpRequest=(HttpServletRequest)request; String strBackUrl = &qu ...
- dom4j API使用简介
dom4j API使用简介 功能简介 dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极 ...
- JSON 之 SuperObject(8): 关于乱码的几种情况 - 向 Henri Gourvest 大师报告
这几天学习 JSON - SuperObject, 非常幸运地得到了其作者 Henri Gourvest 大师的同步指点! (Henri 大师也是 DSPack 和 GDI+ 头文件的作者; 大师是法 ...
- Oracle数据库之二
SELECT查询 函数分为: 单行函数 -- 一条记录进入,一条记录输出 多行函数(分组函数)-- 多条记录进入,按组输出 单行函数: select id,first_name,nvl(commiss ...
- 非常非常非常好!path-sum-iii
https://leetcode.com/problems/path-sum-iii/ 最终我还是没做出好的解法.还是看的别人的解法. 即使看了别人的解法,开始还实现错了. 还有很长的路要走. pac ...
- 基于UltraVNC实现客户端远程控制
前言 一般远程就直接用windows自带的,配置好动态IP花生壳,在任何地方都可以连回机子.最近项目里遇到这么个情况,需要快速接入远程控制功能,客户机的IP每次都会变,并且都是在外网,这样,就必须使用 ...
- Qt之QHeaderView自定义排序(获取正确的QModelIndex)
简述 前几节中分享过关于自定义排序的功能,貌似我们之前的内容已经可以很好地解决排序问题了,但是,会由此引发一些很难发现的问题...比如:获取QModelIndex索引错误. 下面,我们先来实现一个整行 ...