缓存双写一致性

1、先更新数据库,再更新缓存

问题一:redis若更新失败会发生mysql和redis数据不一致的情况(比如向某个redis集群里写数据,在往某个主机里写数据的时候,主机挂了,集群里从机正在准备上位,没空响应写命令)

问题二:写入覆盖

 2、先更新redis,在更新数据库

这种方式不推荐,业务上一般把mysql数据库中的数据作为底单,保证最后的解释性

①问题一

类似于第一种方法,也会出现redis和mysql数据不一致的现象

3、先删除缓存,在更新数据库 

删除完缓存后,第一个到达的请求在redis中没有找到数据,会到mysql中查找并回写到redis,这样就保证了redis和mysql数据一致。

存在的问题:

 

 

 解决方法:延时双删

首先悲观的认为一定会有线程B在线程A更行mysql数据库的时候方位该数据

 延时双删不是强一致性的这样也存在一些问题,

①线程应该sleep多长时间

因为当线程B发现缓存中没有数据后,会向mysql申请这个数据的值(而此时线程A还没有完成数据的更新),若果sleep的时间过短,线程A在线程B向redis中写入旧值之前做第二次删除操作,然后线程B有往redis中写入了旧值(而在此之前线程A已经在mysql将数据更新为了新值),这就造成了redis和mysql数据不一致的情况

 ②同步淘汰会降低吞吐量,应该怎么办

 红框内启动一个异步线程用来监控是否更新完mysql,若完成则立刻二次删除。

4、先更新数据库,在删除缓存(主流)

虽然存在问题,但相对上面三种来说危害较小。

但这样可能存在线程A更新失败的情况,解决方法用到了消息队列,如下图所示

 五、总结

(一般用MQ作为兜底的方案) 

先动redis还容易造成更多的请求访问mysql,集火了,压力太大

六、落地实战

 对Mysql的操作进行监控,最重要的是binlog日志

 需要一种技术方案,能监听到mysql的变动通知redis(既是监听者又是吹哨人),用阿里巴巴的canal

canal作用:

Mysql主从复制原理:

 

canal工作原理、

总的来说,canal会模仿mysql从机向mysql主机访问数据实现主从一致

 实操:

①mysql端

 ps:开启MYSQL的binlog写入功能要修改mysql.ini文件,参考相关视频

 授权canal连接mysql账号

 

 ②canal服务端

注意,canal在linux端,要安装好jdk8

 

 

③编写JAVA业务代码(canal客户端代码)

将canal检测到的更改操作(被修改的数据)通过java代码回写到redis

 

SQL脚本:建立被监控的表

 

详细步骤参考下图中的canal官网

业务类:主要由 增 删 改 打印实体  ,其中启动的只有main函数

 main函数启动后,每秒会打印日志

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Redis双一致性是指在数据库与Redis缓存中同时进行操作时,确保数据的一致性。在双一致性中,存在几个常见的问题,包括缓存雪崩、缓存穿透和缓存并发竞争等。 缓存雪崩是指在某个时间点,大量缓存失效导致请求直接落到数据库上,造成数据库压力骤增。为了避免缓存雪崩,可以采用设置不同的过期时间或使用互斥锁机制来保证缓存的稳定性。 缓存穿透是指恶意或非法请求查询缓存中不存在的数据,导致大量请求落到数据库上,增加数据库的负载。为了解决缓存穿透问题,可以使用布隆过滤器等技术来过滤掉无效请求。 缓存并发竞争是指多个线程同时对同一个缓存进行操作,可能导致数据不一致的问题。为了保证缓存一致性,可以采用延时双删策略,在数据库之前删除一次缓存,在完数据库后,间隔一段时间再删除一次缓存。这样可以增加缓存删除的可靠性和容错性。 另外,要保证Redis双一致性,还可以通过配置Redis策略来进行优化和控制。根据实际情况选择合适的策略,例如使用缓存更新策略或读分离策略等,以提高系统的性能和可靠性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [总结redis实战解决方案](https://download.csdn.net/download/zxfmamama/85931055)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Redis:缓存(双一致性问题](https://blog.csdn.net/wzngzaixiaomantou/article/details/126879335)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值