redis缓存如何保证一致性

ashoftime ashoftime     2022-12-07     241

关键词:

为什么使用Redis做缓存

MySQL缺点

  • 单机连接数目有限
  • 对数据进行写速度慢

Redis优点

  • 内存操作数据速度快
  • IO复用,速度快
  • 单线程模型,避免线程切换带来的开销,速度快

一致性问题

  读数据的时候首先去Redis里读,没有读到再去MySQL里读,读回来之后更新到Redis里作为下一次的缓存。写数据的时候回产生数据不一致的问题,无论是先写到Redis里再写MySQL还是先写MySQL再写Redis,这两步写操作不能保证原子性,所以会出现Redis和MySQL里的数据不一致。无论采取何种方式都不能保证强一致性,如果对Redis里的数据设置了过期时间能够保证最终一致性,对架构做的优化只能降低不一致性发生的概率,不能从根本上避免不一致性。

  根据写入的顺序不同分为四种。

 

先删缓存,再更新数据库

  这种操作的问题?

  一般考虑某种策略的问题都是考虑该种策略会不会导致被删除的脏数据由于时序混乱再次被读线程从MySQL中读出来。A线程写数据,B线程读数据,A线程删除了缓存,B线程读数据发现缓存没有命中从数据库中读数据,B线程把读出的旧数据写到Redis里,A线程把新数据写回去。和下面的先写数据库再删缓存相比,这种方式显著的缺点

  • 先删缓存,所以当两个线程并发的时候很大几率会出现缓存不命中,一旦缓存不命中,在写线程修改MySQL完成之前读进来的永远是脏数据
  • 在缓存到期之前Redis里一直是脏数据

  解决策略

  延迟双删,双删就是在更新完数据库后再删一次。不过延迟双删中更新数据库之前的删除还有什么意义?延迟的目的是为了删除在写MySQL期间读线程可能把脏数据再次读到Redis里,延迟的时间参照一次从MySQL读数据并写入Redis的时间

 

Cache Aside Pattern--先写数据库,再删缓存

  为什么更新数据库后不更新而是删除缓存?

  • 更新缓存的操作不是必须的。可能缓存里的数据并没有被读到,就会被下一次更新MySQL操作带来Redis更新操作覆盖,那么本次更新操作就是无意义的。
  • 更新缓存代价大。如果缓存里的数据不是把MySQL里的数据直接存下来,而是需要经过某种复杂的运算,那么这种不必要的更新会带来更大的浪费。

  这种操作的问题?

  • 并发问题。A线程读数据但没有命中,B线程写数据。A线程读到了MySQL的旧数据,B线程写了新的数据进MySQL,B线程删除了Redis中旧数据的缓存,A用旧数据写到了Redis缓存里。此时Redis里就是旧的脏数据。但这种case出现的概率较低,需要Redis缓存失效同时出现线程写入操作,而且理论上A线程从MySQL中读数据应该更快的返回。

  解决方案?

  每个写MySQL线程写完后延时一定时间在去删Redis中的缓存。

 

Write Behind Caching Pattern--只更缓存,不更MySQL,MySQL由缓存异步的更新

 

  

  

 

redis11_缓存和数据库一致性如何保证解决方案提供canel解决数据一致性问题

文章目录①.缓存和数据库双写一致保证②.缓存数据一致性-解决方案③.缓存数据一致性-解决-Canal①.缓存和数据库双写一致保证①.只要用缓存,就可能会涉及到缓存与数据库双存储双写,你只要是双写,就一定会有数据一致性的问... 查看详情

mysql和redis数据如何保持一致

...的性能。关于如何保证Mysql和Redis中的数据一致(即缓存一致性问题),这是一个非常经典的问题。使用过缓存的人都应该知道,在实际应用场景中,要想实时刻保证缓存和数据库中的数据一样,很难做到。基本上都是尽可能让... 查看详情

如何保证数据库与redis缓存数据一致性(代码片段)

既然要解决这个问题,那么首先要大概了解为啥会出现数据不一致呢?根本原因是我们无法将数据库更新操作与缓存更新操作放在同一个事务内同步成功,同步失败!一、常见操作及问题1.1、先更新数据库,... 查看详情

分布式系统——并发条件下如何保证缓存与db数据一致性

什么是数据一致性我们常说的数据一致性指的是在程序运行过程中本地缓存、分布式缓存、数据库三者之间的数据一致性常见的本地缓存有hashmap、currenthashmap、guavacache、caffeine分布式缓存常见的有redis、memcache常见数据不一致常... 查看详情

如何保证mysql和redis的数据一致性?10张图带你搞定!

... 本文的主要思路是首先带大家认识了解MySQL和Redis的数据一致性情况,然后进行反推不一致的情况,从而进行探究单线程中的不一致的情况。同时探究多线程中的不一致的情况,拟定数据一致性策略。一、什么是数据... 查看详情

美团二面:redis与mysql双写一致性如何保证?

...,有位好朋友去美团面试。他说,被问到Redis与MySQL双写一致性如何保证?这道题其实就是在问缓存和数据库在双写场景下,一致性是如何保证的?本文将跟大家一起来探讨如何回答这个问题。公众号:捡田螺的小男孩谈谈一致... 查看详情

趣说|数据库和缓存如何保证一致性?

作者:小林coding图解计算机基础网站:https://xiaolincoding.com/一天,老板说「最近公司的用户越来越多了,但是服务器的访问速度越来越差的,阿旺帮我优化下,做好了给你画个饼!」。程序员阿旺听到老板口中的「画饼」后就非... 查看详情

如何保证数据库和缓存双写一致性?(代码片段)

...大家见面了。前言数据库和缓存(比如:redis)双写数据一致性问题,是一个跟开发语言无关的公共问题。尤其在高并发的场景下,这个问题变得更加严重。我很负责的告诉大家,该问题无论在面试,还是工作中遇到的概率非常... 查看详情

如何保证数据库与redis缓存数据一致性(代码片段)

既然要解决这个问题,那么首先要大概了解为啥会出现数据不一致呢?根本原因是我们无法将数据库更新操作与缓存更新操作放在同一个事务内同步成功,同步失败!一、常见操作及问题1.1、先更新数据库,... 查看详情

美团二面:redis与mysql双写一致性如何保证?(代码片段)

...有位好朋友去美团面试。他说,被问到Redis与MySQL双写一致性如何保证?这道题其实就是在问缓存和数据库在双写场景下,一致性是如何保证的?本文将跟大家一起来探讨如何回答这个问题。公众号:捡田螺的... 查看详情

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

首先,分为两种场景:一.针对读场景:(1)A请求查询数据,如果命中缓存,那么直接取缓存数据返回即可。如果请求中不存在,数据库中存在,那么直接取数据库数据返回,然后将数据同... 查看详情

高并发下如何保证数据库和缓存双写一致性?(代码片段)

前言数据库和缓存(比如:redis)双写数据一致性问题,是一个跟开发语言无关的公共问题。尤其在高并发的场景下,这个问题变得更加严重。我很负责的告诉你,该问题无论在面试,还是工作中遇到... 查看详情

保证mysql和redis的数据(代码片段)

一、什么是数据的一致性“数据一致”一般指的是:缓存中有数据,缓存的数据值=数据库中的值。但根据缓存中是有数据为依据,则“一致”可以包含两种情况:缓存中有数据,缓存的数据值=数据库中... 查看详情

保证mysql和redis的数据(代码片段)

一、什么是数据的一致性“数据一致”一般指的是:缓存中有数据,缓存的数据值=数据库中的值。但根据缓存中是有数据为依据,则“一致”可以包含两种情况:缓存中有数据,缓存的数据值=数据库中... 查看详情

redis与mysql双写一致性(代码片段)

双写一致性时为了保证Redis缓存与MySQL数据库中的数据一样我们对Redis中没有的数据,MySQL怎么回写呢?我们用双检加锁策略这样只要第一个请求发过来,后面的请求就不会发送到MySQL,直接从Redis中获取缓存数据就可以了。 为... 查看详情

经典好文--如何保证缓存和数据库的双写一致性

面试题如何保证缓存与数据库的双写一致性?面试官心理分析你只要用缓存,就可能会涉及到缓存与数据库双存储双写,你只要是双写,就一定会有数据一致性的问题,那么你如何解决一致性问题?面试题剖析一般来说,如果允... 查看详情

场景应用:如何保证缓存与数据库的双写一致性?

文章目录如何保证缓存与数据库的双写一致性?四种同步策略:同步策略探究更新缓存还是删除缓存:先操作数据库还是缓存:最终结论:补充:延时双删策略采用读写分离的架构怎么办?第二次删除... 查看详情

数据库与缓存一致性问题解决方案

...?Redis突然变慢了如何做性能排查并解决?Redis与MySQL数据一致性问题怎么应对?今天跟大家一起深入探索缓存的工作机制和缓存一致性应对方案。在本文正式开始之前,我们需要先取得以下两点的共识:1)缓存必须要有过期时... 查看详情