这篇文章详细介绍了caffeine_redis自定义二级缓存,文中有相关的背景前提与出现的问题,感兴趣的同学可以参考一下
背景
最近产品下发一个需求:考虑在程序中加缓存,刚开始以为只是 Redis 缓存,后面才直到是本地缓存(Caffeine) + Redis。
在 SpringBoot2.x 后默认的缓存就是 Caffeine,所以本地缓存也选择了 Caffeine。
ps:我们的数据不是从程序中插入或者更新,是每天会有数据专门同步。
问题
基于提出的需求,我认为主要有以下两个问题:
- 因为有本地缓存,如何保证数据一致性。当一个节点数据改变,其他节点的数据如何失效?
- 数据不对,需要重新同步,缓存如何失效?
流程图
接下来就是配合产品和其他开发人员画出流程图,如下:
- 使用一张配置表,记录是否需要缓存,是否开启缓存,来达到通知时候缓存失效的情况。
- 因为项目要求一般,即使消息丢失,也不会存在太大的影响,所以最终选择了 redis 里面的订阅、发布功能,实现通知其他节点失效本地缓存。
开发
上面问题清楚了,流程图也清楚了。那就准备开始写 bug 了。整体思路是自定义注解实现切面,尽量降低对业务代码的耦合度。
CacheConfig
主要是结合业务定义一个 CacheManager,代码里面的解释都有。因为这个是直接占用程序内存的,所有得特别注意最大可缓存条数,别把内存肝爆了。当然也不能太小了,因为还要考虑命中率的问题。所以这就得结合实际得业务来确定最终的大小。
@CaffeineCache
自定义注解,把可以用到的参数都能加上。
CacheMessageListener
缓存监听器,主要是保证多节点数据一致性的问题。当一个节点缓存更新,通知其他的节点相应处理。主要技术是 Redis 的发布、订阅功能,实现 MessageListener 接口。
当然下面还有个细节就是一般生产环境是禁用 Redis#keys 命令的,所以得换个方式扫描对应的 key。
CaffeineCacheAspect
然后就是切面的逻辑处理,里面的内容和 流程图 一模一样,只是使用代码实现了需求。
其中:下面的代码是 Redis 发布消息。
CacheMessage
这是在 Redis 发布消息的时候一个消息体,也是自定义的,可以加更多的参数属性
总结
- Redis 天然适合分布式缓存,但是本地缓存还得考虑数据一致性的问题,这里使用的是 Redis 的发布、订阅功能
- Caffeine 的简单学习了解使用
- 结合自定义注解,使用低耦合的二级缓存
到此这篇关于caffeine_redis自定义二级缓存的文章就介绍到这了,更多相关caffeine_redis二级缓存内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!