文档章节

J2Cache缓存2分钟自动失效原因查找

********
 ********
发布于 2016/09/30 16:39
字数 429
阅读 187
收藏 0

最近在项目内又一次用了j2cache分布式缓存,遇到一个奇怪的问题,用RedisManager监控发现,过2分钟左右会自动清除缓存。

我分析后应该有这几种可能性:

1、redis服务器配置导致缓存定时清除

2、jedis配置导致缓存定时删除

3、ehcache配置导致缓存删除,同时J2Cache内部在被动清除ehcache缓存时也通知redis

4、程序内不小心调用了evict等方法导致缓存失效

 

step1、最先怀疑的是第4点,程序内不小心调用了清除缓存的方法。于是在J2Cache入口处设置断点本地调试,2分钟后缓存失效,未进断点,排除4

step2、接着怀疑第1点,redis服务器配置导致缓存定时清除。于是在程序内调用J2Cache设置缓存,再关闭进程,等待5分钟,缓存未消失,排除1

step3、接着怀疑第2点,jedis配置导致缓存定时删除。我看了下jedis的配置选项,没有关于缓存过期的配置,都是一些关于连接池的配置,基本排除3

step4、最后怀疑是不是J2Cache在一级缓存被动清除时也会通知redis,只能看看J2Cache源码了!

根据“Cache data expired...”这条log找到清除2级缓存的代码位置(RedisCacheChannel.java)

跟踪方法调用位置(EhCache.java)

看到这可以知道,是ehcache缓存失效时通知2级缓存失效导致的。

解决方法:J2Cache每个region对应ehcache.xml里的每个cache.name,根据实际情况配置缓存时间

© 著作权归作者所有

共有 人打赏支持
********

********

粉丝 13
博文 137
码字总数 19574
作品 0
福州
个人站长
J2Cache 2.3.12 发布,支持二级缓存只读模式

J2Cache 推出至今,已有多人希望能提供二级缓存只读模式,相当于应用只能从 Redis 二级缓存读取数据,而不允许写入任何数据,包括当一级缓存失效时也不能去清除二级缓存的数据。这样的开发者...

红薯
04/27
0
0
J2Cache 新增 Mybatis 支持模块,代码少到没 Bug

花了点时间撸了个 MyBatis 的 J2Cache 支持模块,含注释共八十多行代码 (J2CacheAdapter.java),再有 Bug 我就真的要退役了。 使用方法很简单,请看 https://gitee.com/ld/J2Cache/tree/mast...

红薯
05/15
0
30
J2Cache 新增 Hibernate 5 支持,感谢 @tandy 贡献

想了解 J2Cache 是一个什么开源项目,请阅读 这篇博客。 J2Cache 刚新增对 Hibernate 5 的支持,提供了 j2cache-hibernate5 模块,可以方便在 Hibernate 5 中启用 J2Cache 缓存。 该模块由 ...

红薯
09/28
0
1
使用 fastjson 实现类型无关的对象序列化

今天跟 fastjson 作者 @wenshao 聊了会才找到 fastjson 如何实现类型无关的对象序列化 代码如下: J2Cache 已经新增了这个特性,详情请看这里。 J2Cache 使用 JSON 进行缓存数据序列化的方式...

红薯
08/08
0
0
J2Cache 2.5.5 发布,完善对 Sentinel 的 pub/sub 支持

J2Cache 2.5.5 发布了,该版本主要改进内容包括: 完善对 Redis Sentinel 的 pub/sub 支持 修复了 json 序列化不支持 java.sql.Date 和 java.sql.Timestamp 的问题 修复 Spring Boot 模块的序...

红薯
09/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

将桌面捕获到虚拟摄像头

当然你可以直接用现成的虚拟摄像头软件实现这个功能。不过当初我开发这个插件的原因是,需要在Flash产品里面共享桌面,如果此时需要引导用户安装一个第三方的虚拟摄像头体验不好,所以公司希...

一个灰
4分钟前
0
0
Linux 配置网络绑定

1. 常见的网卡绑定驱动模式: mod=0 (balance-rr) Round-robin 衡抡循环策略 特点: 传输数据包顺序是依次传输(即:第1个包走eth0,下一个包就走eth1.一直循环下去,直到最后一个传输完毕),...

JeremyTown
13分钟前
0
0
VS code 编辑器使用技能

VS code 文档:https://code.visualstudio.com/docs/getstarted/locales 1、安装中文扩展包 打开扩展包按钮(最左上角从上往下数第5个按钮或者快捷键 Ctrl + Shift + X) 搜索语言包categor...

削个椰子皮_给个梨
22分钟前
0
0
Django 2.1.2项目中创建一个应用

Django 2.1.2项目中创建一个应用: 1.新建一个应用(app), 名称叫 learn python manage.py startapp learn # learn 是一个app的名称 2.在learn应用中修改视图文件views.py: # Create your vi...

MichaelShu
23分钟前
0
0
Swagger中配置了@ApiModelProperty的allowableValues属性但不显示的问题

现在用Swagger来生成API文档的例子已经非常多了,今天碰到开发同事问了一个问题,帮着看了一下,主要还是配置方法的问题,所以记录一下。如果您也碰到了同样的问题,希望本文对您有用。 问题...

程序猿DD
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部