【HBZ分享】高并发下更新数据库和Redis缓存的顺序问题

场景一:先更新数据库,再更新缓存

  1. A线程更新数据库
  2. A线程再更新缓存
  3. 线程A更新数据库时commit失败, 进行了rollback,导致DB没更新数据,但此时却把redis缓存更新了
  4. 导致缓存和数据库不一致

场景二:先删除缓存,再更新数据库

  1. 线程A删除缓存,然后去更新数据库,此时数据库还没commit
  2. 线程B访问缓存,此时缓存已被A线程删除,所以去数据库读取数据,但由于还没commit,所以B读取数据库取出的是老数据,并把老数据存入了redis缓存
  3. 线程A此时进行了commit, 数据库更新了最新数据,但此时缓存已经有数据了,并且是B存的老数据
  4. 此时数据不一致了,缓存老数据, DB新数据

场景三:先删除缓存,再更新数据库,再删除缓存(第二次删除可以异步)

  1. 线程A删除缓存,然后去更新数据库,此时数据库还没commit
  2. 线程B访问缓存,此时缓存已被A线程删除,所以去数据库读取数据,但由于还没commit,所以B读取数据库取出的是老数据,并把老数据存入了redis缓存
  3. 线程A此时进行了commit, 数据库更新了最新数据,但此时缓存已经有数据了,并且是B存的老数据,此时数据库与缓存数据不一致
  4. 线程A再次删除redis缓存,此时B存入的老数据又被删除了,redis再次为空,没有对应数据
  5. 线程C来了,发现缓存没数据,所以从数据库查数据, 此时A已经commit了,所以数据库是新数据
  6. C线程将DB查询的数据放入缓存。
  7. 此时缓存与数据库都是新数据,但浪费了一次IO
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值