数据一致性

怎么保证数据一致性?

首先为了保证速度,我们设计系统的时候会先查询缓存,没有命中缓存再去查数据库(),数据一致性问题发生在(主要两步,写表和删缓存)
那么问题究竟是什么呢,

(场景:线程A修改操作,线程B读取数据)
1、先删缓存在写表
线程A把缓存删了还没写表,线程B发现没有命中缓存,查询到旧数据,写入缓存,造成数据不一致

2、先写表在删缓存
a.缓存设有过期时间,线程B先进来,缓存过期了,线程B读取数据库旧数据,这时候线程A写入了新数据,并且删除了缓存,然后线程B把读取的旧数据写入缓存,造成数据不一致

b.线程A写完表后挂了,导致缓存没删除,造成数据不一致

那么怎么保证数据一致性呢
采用分布式锁,
解决方案(1):分布式锁,具体流程为:

1、把写表和删缓存看成是一个整体,每个想要操作的线程都必须先申请分布式锁;

2、如果成功获得锁,则进行数据库和缓存操作,操作完毕释放锁;

3、如果没有获得锁,根据不同业务可以选择阻塞等待或者轮询,或者直接返回的策略。

(2)延迟双删
1、删除缓存,2、写入数据,等待一定时间,3、删除缓存
为啥要等待一定时间?为了防止上面提到的第二种情况,被线程B读取到旧数据写入到缓存,具体等待时间随系统情况定,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值