Java面试 Redis篇-双写一致性问题

hello大家好,这里是花栗鼠鼠鼠,下面我们来介绍双写一致性问题!

首先我们要了解,何为双写一致性呢?

根据字面意思我们可以理解为,两次写操作写入的数据是一致的,那么这两次写指的就是数据库写入和缓存写入。所以定义是:双写一致性指的是在向数据库写入数据时,同时也要改变缓存中的数据,保证DB和缓存的数据一致。

那么,在高并发的情况下,可能会有多次请求去访问同一个数据,当我们在这时修改数据时不论是先删除缓存再修改数据库,还是先修改数据库再删除缓存,都有可能读到脏数据(数据已经被修改了,但是我们读到了未修改的数据),这时怎么去解决这个问题呢?

第一种是对于要求强一致性的数据:使用redisson提供的读写锁,在读数据时使用共享锁,其他线程可以进行读操作,但是不能写;在写数据时使用排他锁,其他线程不可读且不可写。

第二种情况是对于允许延迟一致(缓存和数据库中的数据同步可以延迟一小会)的情况:可以使用异步通知保证数据的最终一致性,例如:

①使用MQ中间件,更新数据之后,通知缓存删除。

②利用canal中间件,不需要修改业务代码,伪装为mys

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值