Redis-如何保证缓存和数据一致性

不一致问题:

  • 先修改数据库,再更新缓存:
  1. 缺点:如果在修改数据库之后更新缓存之前出现问题,出现数据不一致
  2. 解决方案:先删除缓存,再修改数据库
  • 先删除缓存,再修改数据库:
  1. 缺点:如果在删除缓存之后修改数据库之前,出现另一个线程去读缓存发现缓存为空,又从数据库拉取还没被修改的旧数据到缓存,导致数据不一致(注:只有在对一个数据在并发的进行读写的时候,才可能会出现这种问题。其实如果说你的并发量很低的话,特别是读并发很低,每天访问量就 1 万次,那么很少的情况下,会出现刚才描述的那种不一致的场景)
  2. 解决方案:在修改数据的时候,在JVM内部队列中放入这条数据的唯一标识,当另一个请求过来发现缓存中数据为空时先不去数据库拉取数据,而是把这个请求也放到内部队列中,等前面的修改操作执行完再去拉取数据(注:一个队列中,其实多个更新缓存请求串在一起是没意义的,因此可以做过滤,如果发现队列中已经有一个更新缓存的请求了,那么就不用再放个更新请求操作进去了,直接等待前面的更新操作请求完成即可。)

 

参考:

  1. 如何保证缓存和数据一致性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值