如何保证数据库与缓存的数据一致性

一. 先删redis,再修改数据库

数据不一致的情况:

一、 线程A修改数据时,需先执行删除缓存操作

二、其他线程只要在线程A删除缓存和执行update期间,查询数据库得到了旧的数据,此时就有极大的概率会出现数据不一致的情况。

二. 先修改数据库,再删redis(相比先删缓存可能出现数据不一致的概率要小)

数据不一致的情况:

一、 线程A读取数据,刚好缓存失效了,去查询数据库数据,刚要执行放入redis缓存时,CPU发生上下文切换,线程A暂时得不到执行

二、此时线程B修改数据,执行update商品操作,然后删除缓存

三、线程A执行时,将之前查询到的旧的数据存到redis缓存中,此时就会出现redis和数据库的数据不一致的情况。

三.延时双删

在对数据库操作前后各进行一次删除缓存key的操作,设置合理的超时时间

  1. 先删除redis
  2. 再修改数据库
  3. 等待一段时间(几百毫秒)后再次删除redis
public void write( String key, 
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值