我们目前是这么实现的。 caffeine + redis 消息订阅。对外暴露的接口加上 caffeine 缓存,如果数据修改了,通过 redis 主动推送消息,有一个 handler 来接收消息让缓存过期。比如缓存空间是 activity,key 是 activityId,那么收到消息就会去过期这个空间的这个 key 。
但是这样吧,总感觉有点乱,因为过期缓存需要指定缓存的 key,项目里面开发的人又多,key 很多,有时候还会忘了在 handler 里面加上让指定 key 过期的逻辑。不知道大家一般都是怎么做的。
1
dqzcwxb 2021-03-17 17:59:49 +08:00
这是人的问题
|
2
killergun 2021-03-17 18:11:10 +08:00
有没有试过 Client side caching
|