近期,发现在预发布环境上的项目有些冲突,本着治病救人的原则,不得已要一步步剖析,苦逼的就是我们可爱可敬的程序员。

先介绍下大体情况,应用项目都是velocity+spring+mybatis,没什么好说的,spring配置了一个sso的filter,filter中使用了coherence3.5.3作为缓存,项目打成war包后部署在jboss eap 6.3域模式下(两台物理机,每个上起一个server实例,属于同一group),由于有些jar包是公用的,这些jar包作为jboss的module部署在jboss上,其中就包括coherence.jar。一个war包部上后是正常的,再部一个war,上一个war的ssofilter就出现异常,似乎缓存的东西没了。

开始找人来看,让我们换成Ehcache,好吧,换。。。,倒是好了,没想到过几天问题来了,ehcache都是local存储的,一个应用一个cache,原来的coherence会自动组群,删一次就ok了,现在要一个一个的删,不够nice,想想还是要弄明白coherence到底是怎么了?

注意力再次集中在coherence上,百度一下,没有答案,百度一下,没有答案。。。倒是看了一些介绍性的文章和翻译的中文文档,大体知道coherence可以通过组播地址自动组群,构成集群。再看我们的项目,coherence配置都是一样的,难道要区别?试试吧,折腾好半天没好,卸大半气了。一直以来怀疑是我们在jboss上部署的公共模块有问题,后来在本机上搭了个环境,各种奇淫技巧用上,看日志嘛,分析来分析去,发现如果两个war包部在两个jboss server上没有问题,第一个war会建一个集群,并把自己加进去,第二个war再部署,会自动加入第一个war建的集群中,正常啊。如果放在一个server中,第一个正常,第二个好像不是一个节点,没有coherence的日志,使用的应该是第一个war包创建的node,下图Id=1就是第一个war包的节点信息

然后,在jboss上replace第二个war包

可以看到Id=1(由第一个war创建)的节点left,第二个war产生一个Id=2的节点,如果操作第一个war包的cache,会出现类似下面的日志

出现这样的日志也与我们的项目有关,

public class NamedCacheFactoryBean implements FactoryBean<NamedCache>, InitializingBean, DisposableBean {
。。。。。
@Override
public void destroy() throws Exception {
if (this.ensureCluster) {
CacheFactory.shutdown();
}
} @Override
public void afterPropertiesSet() throws Exception {
if (this.ensureCluster) {
CacheFactory.ensureCluster();
}
this.cache = CacheFactory.getCache(this.cacheName);
for (MapListener mapListener : mapListeners) {
this.cache.addMapListener(mapListener);
}
}
。。。。。
}

第二个war包replace导致共享的node关闭,第二个war产生一个Id=2的节点仅第二个war包使用,第一个war包使用异常,估计是像CacheFactory.shutdown()这样操作的问题,只要保持各个war包独立就可以了吧,把coherence.jar从jboss公共模块上拉下来,打包到war里面,后来的测试很顺利,每个war包有单独的node

期间还发现一个问题:同样的配置coherence.jar作为公共模块,tangosol-coherence-override.xml配置不起作用,出现类似

Optional configuration override "coherence/preproduct/tangosol-coherence-override.xml" is not specified

的日志,而打包到coherence.jar中就可以,看来coherence找这个配置路径时是依赖class加载路径的,其实也可以把这些配置文件打包到jar包中,不过,这样的话就限制了这个jar的使用,不太好

参考文章:

1. Oracle Coherence中文教程七:设置群集

2. Coherence Step by Step 第二篇 集群(二) 建立集群

3. 分布式网格缓存Coherence简介

coherence初识的更多相关文章

  1. coherence配置说明

    经过上篇 coherence初识 ,最近算是和coherence杠上了,针对coherence3.5.3这个版本,把学到的东西整理下 1. 这个jar包有点大,4M多,首先打开coherence.ja ...

  2. Android动画效果之初识Property Animation(属性动画)

    前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ...

  3. 初识Hadoop

    第一部分:              初识Hadoop 一.             谁说大象不能跳舞 业务数据越来越多,用关系型数据库来存储和处理数据越来越感觉吃力,一个查询或者一个导出,要执行很长 ...

  4. python学习笔记(基础四:模块初识、pyc和PyCodeObject是什么)

    一.模块初识(一) 模块,也叫库.库有标准库第三方库. 注意事项:文件名不能和导入的模块名相同 1. sys模块 import sys print(sys.path) #打印环境变量 print(sy ...

  5. 初识IOS,Label控件的应用。

    初识IOS,Label控件的应用. // // ViewController.m // Gua.test // // Created by 郭美男 on 16/5/31. // Copyright © ...

  6. UI篇(初识君面)

    我们的APP要想吸引用户,就要把UI(脸蛋)搞漂亮一点.毕竟好的外貌是增进人际关系的第一步,我们程序员看到一个APP时,第一眼就是看这个软件的功能,不去关心界面是否漂亮,看到好的程序会说"我 ...

  7. Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

    Python导出Excel为Lua/Json/Xml实例教程(一):初识Python 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出 ...

  8. 初识SpringMvc

    初识SpringMvc springMvc简介:SpringMVC也叫Spring Web mvc,属于表现层的框架.Spring MVC是Spring框架的一部分,是在Spring3.0后发布的 s ...

  9. 初识redis数据类型

    初识redis数据类型 1.String(字符串) string是redis最基本的类型,一个key对应一个value. string类型是二进制安全的.意思是redis的string可以包含任何数据 ...

随机推荐

  1. 依赖包bcrypt安装Issues

    说明:本文在个人博客地址为edwardesire.com,欢迎前来品尝. 在决策树项目中,使用到了bcrypt依赖包来加密文件.在wini8(win7)部署安装这个依赖的时候容易出现出现了问题. 解决 ...

  2. 第二百九十、一、二天 how can I 坚持

    上周日,腊八,好冷,去菏泽了.坐火车,没座.好冷,下午菏泽学院,大体看了看,很是怀念,有点遗憾,在网吧玩的时间太长了,留不住. 周一,长太婚礼,竟然没有只是吃了个饭,有点小失望,下午坐车回京,两点坐的 ...

  3. Linux数据流重定向

    一.什么是数据流重导向: 数据流重导向 (redirect) 由字面上的意思来看,好像就是将『数据传导到其他地方去』,没错-数据流重导向就是将某个命令运行后应该要出现在屏幕上的数据, 给他传输到其他的 ...

  4. Android问题-打开DelphiXE8与DelphiXE10编译空工程提示“[Exec Error] The command exited with code 1.”

    问题情况:开发了半天的D2007代码,想测试一个安桌程序,发现新建空工程,提示失败. 提示如下 Exec Error] The command PATH C:\Program Files (x86)\ ...

  5. POJ 3159 Candies(差分约束,最短路)

    Candies Time Limit: 1500MS   Memory Limit: 131072K Total Submissions: 20067   Accepted: 5293 Descrip ...

  6. How to include cascading style sheets (CSS) in JSF

    In JSF 2.0, you can use <h:outputStylesheet /> output a css file. For example, <h:outputSty ...

  7. C#中垃圾回收与内存管理机制

    今天抽空来讨论一下.Net的垃圾回收与内存管理机制,也算是完成上个<WCF分布式开发必备知识>系列后的一次休息吧.以前被别人面试的时候问过我GC工作原理的问题,我现在面试新人的时候偶尔也会 ...

  8. hdu 4578 Transformation(线段树)

    线段树上的多操作... 题目大意: 树上 的初始值为0,然后有下列三种操作和求和. 1  x y c  在X-Y的之间全部加上C. 2  x y c  在X-Y的之间全部乘上C. 3  x y c   ...

  9. RIA(富客户端)发展态势

    在过去的两到三年中,Web开发人员一直是想构建一种比传统HTML更丰富的客户端:这是一个用户接口,它比用HTML能实现的接口更加健壮.反应更加灵敏和更具有令人感兴趣的可视化特性.RIA技术的出现允许我 ...

  10. wikioi 3027 线段覆盖 2

    题目描述 Description 数轴上有n条线段,线段的两端都是整数坐标,坐标范围在0~1000000,每条线段有一个价值,请从n条线段中挑出若干条线段,使得这些线段两两不覆盖(端点可以重合)且线段 ...