22 Star 86 Fork 36

xiaolyuh / layering-cache

加入 Gitee
与超过 600 万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README.md

layering-cache

Maven Central License

简介

layering-cache是一个支持分布式环境的多级缓存框架,使用方式和spring-cache类似。它使用Caffeine作为一级本地缓存,redis作为二级集中式缓存。一级缓存和二级缓存的数据一致性是通过推和拉两种模式相结合的方式来保证。推主要是基于redis的pub/sub机制,拉主要是基于消息队列和记录消费消息的偏移量来实现的。

支持

  • 支持缓存命中率的监控统计,统计数据上报支持自定义扩展
  • 内置dashboard,支持对缓存的管理和缓存命中率的查看
  • 支持缓存过期时间在注解上直接配置
  • 支持缓存的自动刷新(当缓存命中并发现二级缓存将要过期时,会开启一个异步线程刷新缓存)
  • 缓存Key支持SpEL表达式
  • Redis支持Kryo、FastJson、Jackson、Jdk和Protostuff序列化,默认使用Protostuff序列化,并支持自定义的序列化
  • 支持同一个缓存名称设置不同的过期时间
  • 支持禁用一级缓存,只使用二级缓存

优势

  1. 提供缓存命中率的监控统计,统计数据上报支持自定义扩展
  2. 支持本地缓存和集中式两级缓存
  3. 接入成本和使用成本都非常低
  4. 无缝集成Spring、Spring boot
  5. 内置dashboard使得缓存具备可运维性
  6. 通过缓存空值来解决缓存穿透问题、通过异步加载缓存的方式来解决缓存击穿和雪崩问题

文档

中文文档

Redis序列化方式对比

Redis序列化同一个User对象对比

size serialize(get 10W次) deserialize(set 10W次) serialize(cup) deserialize(cup)
Kryo 273 b 82919 ms 90917 ms 8% 12%
FastJson 329 b 15405 ms 18886 ms 12% 13%
Jackson 473 b 16066 ms 16140 ms 15% 14%
Jdk 1036 b 17344 ms 24917 ms 14% 13%
Protostuff 282 b 14295 ms 14355 ms 15% 13%

打开监控统计功能

打开监控统计功能

重要提示

  • layering-cache支持同一个缓存名称设置不同的过期时间,但是一定要保证key唯一,否则会出现缓存过期时间错乱的情况
  • 删除缓存的时候会将同一个缓存名称的不同的过期时间的缓存都删掉
  • 在集成layering-cache之前还需要添加以下的依赖,主要是为了减少jar包冲突(依赖jar列表)。
  • redis的key序列化方式必须StringRedisSerializer

更新日志

更新日志

实现原理

实现原理

作者信息

作者博客:https://xiaolyuh.blog.csdn.net/

作者邮箱: xiaolyuh@163.com

github 地址:https://github.com/xiaolyuh/layering-cache

捐赠

项目的发展离不开你的支持,请作者喝杯咖啡吧!

微信-支付宝

技术支持

添加微信记得备注 layering-cache,捐赠用户可享有需求优先解决、协助部署、二次开发帮助。

微信

仓库评论 ( 5 )

你可以在登录后,发表评论

简介

为监控而生的分布式多级缓存框架 展开 收起
Java 等 4 种语言
取消

发行版

暂无发行版

layering-cache

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/xiaolyuh/layering-cache.git
git@gitee.com:xiaolyuh/layering-cache.git
xiaolyuh
layering-cache
layering-cache
master

搜索帮助

141041 ab9339c7 1850385 141043 25c028d5 1850385