1. 增加配置文件cluster.xml

    将配置包resource文件夹下的cluster.xml打开,如果没有cluster.xml,则新建一个,基本内容如下:

    <?xml version="1.0" encoding="UTF-8" ?>

    <ClusterConfig useCluster="true">      //useCluster=”true”表示启用集群配置

    <ClusterService>

    <ServiceName>A</ServiceName>  //给这台服务器取一个区别于其他机器的别名

    <ip>192.168.0.1</ip>            //这台服务器在内网中的IP地址

    <port>8080</port>              //报表应用的端口

    <WebAppName>WebReport</WebAppName>  //报表应用的名称

    </ClusterService>

    <ClusterService>

    <ServiceName>B</ServiceName>

    <ip>192.168.0.2</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    </ClusterConfig>

  2.  

    这里的每个ClusterService都是集群中一台服务器的相关信息。配置好后,系统会根据自身的IP和端口号去匹配找到相应的信息。当然也可能会有一些原因导致系统无法正确的匹配找到。这时您可以设置isSelf属性来指定自身的属性。

    注:xml文件的第一行<??>前面不能有空格,并且请注意xml文件的编码。

    另:xml文件的保存格式是 utf-8 no Bom的格式。一般用写字板打开配置包下的cluster.xml文件,修改保存就可以。

  3.  

    示例

    例如这个配置文件部署在A服务器下,那么ServiceName为A的那个ClusterService节点后加一个属性 isSelf=”true”,表示下这是本机的信息。如下所示:

    <?xml version="1.0" encoding="UTF-8" ?>

    <ClusterConfig useCluster="true" userShare="true">

    <ClusterService  isSelf="true"> //A服务器的配置信息,后面增加了属性isSelf=”true”表示本机

    <ServiceName>A</ServiceName>

    <ip>192.168.0.1</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    <ClusterService> //B服务器的配置信息

    <ServiceName>B</ServiceName>

    <ip>192.168.0.2</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    </ClusterConfig>

    ServiceName是为一台服务器取的别名,只是为了区别标记一下。最好简单方便,如A、B、C或者A1、A2等。注意!不能是中文。

  4.  

    IP是该台服务器内网中的IP,就是其它服务器能与之通信的IP。

    Port是报表应用的端口号,假如是部署在tomcat下,那么就是tomcat的端口号,默认是8080.例如我们的内置服务器是8079.

    WebAppName是报表应用的名称,我们默认的是WebReport。

    那么,B服务器下的cluster.xml的配置信息如下:

    <?xml version="1.0" encoding="UTF-8" ?>

    <ClusterConfig useCluster="true" userShare="true">

    <ClusterService> //A服务器的配置信息

    <ServiceName>A</ServiceName>

    <ip>192.168.0.1</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    <ClusterService  isSelf="true"> //B服务器的配置信息,后面增加了属性isSelf=”true”表示本机

    <ServiceName>B</ServiceName>

    <ip>192.168.0.2</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    </ClusterConfig>

    那么正确的配置结果,就是在A服务器上,假如有浏览器,浏览器中输入

    http://192.168.0.2:8080/WebReport/ReportServer?reportlet=xxx.cpt ,就能访问到B服务器上的报表应用。这个url中的IP、端口号和web应用名称就是上面配置信息里的。注:xxx.cpt只是举个例子

  5.  

    那综上说明,假如集群中多了一台C服务器,给它取个别名就叫C。内网IP是192.168.0.3,装了tomcat,端口默认是8080。报表应用名称也是默认是WebReport。那么服务器下的配置文件,应该如下所示:

    <?xml version="1.0" encoding="UTF-8" ?>

    <ClusterConfig useCluster="true" userShare="true">

    <ClusterService>

    <ServiceName>A</ServiceName>

    <ip>192.168.0.1</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    <ClusterService>

    <ServiceName>B</ServiceName>

    <ip>192.168.0.2</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    <ClusterService>

    <ServiceName>C</ServiceName>

    <ip>192.168.0.3</ip>

    <port>8080</port>

    <WebAppName>WebReport</WebAppName>

    </ClusterService>

    </ClusterConfig>

    最后,请根据上面的格式,写好cluster.xml文件,且将其拷贝到各服务器的报表应用(WEB-INF\resources)文件夹下。当然,有isSelf属性指定的特定服务器的配置文件,还需保存到相应的服务器路径下。

  6.  

    测试配置是否生效

    当集群中的服务器都已经按照上述步骤配置好,且重新启动报表应用后,测试各个服务器之间的通讯是否正常。

    例如,在A服务器下,先本机测试下报表能否访问,测一张简单的模板就行。能正常访问(ie浏览器可能需要将其localhost或127.0.0.1的本机地址,添加到信任站点中才能显示页面),接着在浏览器上输入:http://localhost:8080/WebReport/ReportServer?op=fr_cluster&cmd=test_c_all

    上述url地址,其前面的部分,按情况换上相应报表应用的端口号和应用名称。而后,假如本机设置正常,就能看到如下的信息:(以上述A、B两台服务器的配置文件举例)

    Cluster is start

    SELF:

    ServiceName:B

    IP:192.168.100.227

    PORT:8080

    WebAppName:WebReport

    Other Server List:

    NO1: ServiceName:A = 192.168.100.227:7080/WebReport

    ------------------------------------------

    Test it(op = cluster_test) - RE:

    Cluster is start!

    Cluster Share is not start!

    SELF:

    ServiceName:A

    IP:192.168.100.227

    PORT:7080

    WebAppName:WebReport

    Other Server List:

    NO1: ServiceName:B = 192.168.100.227:8080/WebReport

  7.  

    这样说明,配置生效,A服务器能与B服务器间能够互相通信。再次查看下信息是否有误。

    假如显示:Cluster is close!,那说明该机的配置没有生效。请检查配置文件后,重新启动应用,且再次依照上面步骤测试,直至出现上面的结果为止。

    假如前面一部分显示是这样:

    Cluster is start!

    Can not find Own Service Info.

    LocalIP:192.168.0.39

    LocalPort:8070。

  8.  

    说明集群配置了,但系统无法根据自身找到的IP和端口匹配到配置文件中的信息。而系统找到的IP是192.168. 0.39,端口是8070。可能您配置成了192.168.0.38:8080,那系统就找不到相应的节点信息了。当然由于各种原因,可能系统无法拿到正确的IP和端口,这时请您检查后,设置正确的IP和端口后,在相应的ClusterService的节点上加isSelf属性(isSelf=”true”)。

    假如,SELF下的信息不正确,或没有信息,也请检查配置文件。

    假如,下面列出的其它机器的信息不正确,或有遗漏,也请检查配置信息后,重启报表应用重试。

    假如,其它服务器的回应,没有回应OK,例如回应Connection timed out: connect。请检查下那台服务器的配置信息,检查网络连接,ping下那台机器的ip地址,看看是否能ping通。然后查看那台服务器报表应用的端口和应用名称,是否设置正确。

    可在浏览器中,输入地址直接在内网中访问下那台机上的报表应用,看看设置的ip、端口号等是否设置正确。修改后,重新启动报表应用,重试。

  9.  

    结束

    当以上检查步骤结束。所有服务器都检查,发现正确后。恭喜,配置就完成了。

    来源:http://jingyan.baidu.com/article/91f5db1b323b8d1c7f05e3b9.html

Finereport集群配置的更多相关文章

  1. Ubuntu 14.04中Elasticsearch集群配置

    Ubuntu 14.04中Elasticsearch集群配置 前言:本文可用于elasticsearch集群搭建参考.细分为elasticsearch.yml配置和系统配置 达到的目的:各台机器配置成 ...

  2. Redis 3.0 Cluster集群配置

    Redis 3.0 Cluster集群配置 安装环境依赖 安装gcc:yum install gcc 安装zlib:yum install zib 安装ruby:yum install ruby 安装 ...

  3. MongoDB高可用集群配置的方案

    >>高可用集群的解决方案 高可用性即HA(High Availability)指的是通过尽量缩短因日常维护操作(计划)和突发的系统崩溃(非计划)所导致的停机时间,以提高系统和应用的可用性. ...

  4. MySQL Cluster 7.3.5 集群配置实例(入门篇)

    一.环境说明: CentOS6.3(32位) + MySQL Cluster 7.3.5,规划5台机器,资料如下: 节点分布情况: MGM:192.168.137. NDBD1:192.168.137 ...

  5. MySQL Cluster 7.3.5 集群配置参数优化(优化篇)

    按照前面的教程:MySQL Cluster 7.3.5 集群配置实例(入门篇),可快速搭建起基础版的MySQL Cluster集群,但是在生成环境中,还是有很多问题的,即配置参数需要优化下, 当前生产 ...

  6. 关于ActiveMQ的几种集群配置

    ActiveMQ的几种集群配置. Queue consumer clusters 此集群让多个消费者同时消费一个队列,若某个消费者出问题无法消费信息,则未消费掉的消息将被发给其他正常的消费者,结构图如 ...

  7. solrCloud+tomcat+zookeeper集群配置

    solrcolud安装solrCloud+tomcat+zookeeper部署  转载请出自出处:http://eksliang.iteye.com/blog/2107002 http://eksli ...

  8. RabbitMq 集群配置

    1. RabbitMQ 所需的附属安装包 1.1  openGL安装 执行命令: [root@localhost local]# yum install mesa-libGL-devel mesa-l ...

  9. Spring+quartz 实现定时任务job集群配置

    为什么要有集群定时任务? 因为如果多server都触发相同任务,又同时执行,那在99%的场景都是不适合的.比如银行每晚24:00都要汇总营业额.像下面3台server同时进行汇总,最终计算结果可能是真 ...

随机推荐

  1. Gold Game

    一.项目描述:黄金点游戏 黄金点游戏是一个数字小游戏,其游戏规则是: N个同学(N通常大于10),每人写一个0-100之间的有理数 (不包括0或100),交给裁判,裁判算出所有数字的平均值,然后乘以0 ...

  2. peer not authenticated error

    问题背景 系统:OS X El Capitan,10.11.2 IDE:Android Studio 2.0 Preview Java:1.8.0_65 Gradle:2.3 clone了代码后,在i ...

  3. ASP.NET程序中 抛出"Thread was being aborted. "异常(转)

    Thread was being aborted :中文意思 线程被终止 引用地址:http://support.microsoft.com/default.aspx/kb/312629/EN-US/ ...

  4. URL Regex expression

    转载: http://blog.csdn.net/weasleyqi/article/details/7912647 首先,正则表达式: String check = @"((http|ft ...

  5. Android 软引用

    2013-08-13 13:56 佚名 eoe Android开发者社区 字号:T | T   可能对于Android开发者来说,软引用这个词有的会不是很熟悉,软引用在Java开发中用的比较多,但是, ...

  6. (windows)mongoDB3X+Robomongo的安装与基础配置

    一开始安装的时候还觉得很简单真正装了时候发现网上的资料参差不齐再次整理一份安装方法 ---------------------------------------------------------- ...

  7. xcode-git笔记

    git initgit add .vi .gitignore /*将代码区蓝色字体的内容*/git commit -m "初次建立"git remote add origin ht ...

  8. Swagger-API测试工具实战

    初次通过swagger不知道这是一个什么东东. 一.拿到一个项目需要测试,打开地址一看有个大写的swagger,于是各种脑补: 我所理解的就是,swagger是一个API开发工具或者来说是一个框架,开 ...

  9. VirtualBox双网卡搭建Linux虚拟实验环境

    VirtualBox中有如下几种网络连接方式: NAT(NAT到宿主机IP地址) NAT Network (NAT到宿主机所在的网段,即使用相同的网关和掩码) Bridged Adapter Inte ...

  10. 萌萌的websocket原理解析

    转载自:http://www.zhihu.com/question/20215561 一.WebSocket是HTML5出的东西(协议),也就是说HTTP协议没有变化,或者说没关系,但HTTP是不支持 ...