缓存一致性怎么解决

面试影石的时候,面试官问了我这个缓存一致性的问题,我想这不是很简单吗,就是旁路缓存啊。
读的话先读缓存,缓存命中则返回。缓存未命中,则读数据库,然后将数据写入缓存,再返回。然后写操作: 先更新数据库,再删除缓存。如果删除失败的话,可以引入消息队列(MQ)重试,或者使用Canal订阅Binlog去删缓存。
结果他说这些优化都是太常规了,有没有其他的方法,这个我就说不上来了。删除失败就用这两个解决就行了吧,还要用什么高级的方法啊?
#一人一道大厂面试题#
全部评论
他估计想听基于tk的缓存更新或者基于版本号的
1 回复 分享
发布于 09-07 20:00 重庆
一般这种一旦追问我就答不上来了,我的想法面试官不认可,我怎么可能在短时间内想出来嘛
点赞 回复 分享
发布于 09-11 17:22 陕西
正确方法应该是 Canal
点赞 回复 分享
发布于 09-07 19:04 广东
分布式锁、分布式事务、mq异步更新(?但感觉是大炮打蚊子,一般都很少用到,不理解面试官想法
点赞 回复 分享
发布于 09-07 14:07 辽宁
唉,面试要求也是越来越高了
点赞 回复 分享
发布于 09-06 23:55 安徽
延迟双删吧
点赞 回复 分享
发布于 09-06 17:42 湖北

相关推荐

09-06 21:34
西北大学 Java
查看18道真题和解析
点赞 评论 收藏
分享
评论
3
21
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务