mysql和redis怎么保证数据一致,mysql怎样与redis保持一致性的

首页 > 技术 > 作者:YD1662023-06-10 00:07:37

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

一、什么是数据的一致性

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

“数据不一致”:缓存的数据值≠数据库中的值;缓存或者数据库中存在旧值,导致其他线程读到旧数据。

二、数据不一致性情况及应对策略

根据是否接收写请求,可以把缓存分成读写缓存和只读缓存。

只读缓存:只在缓存进行数据查找,即使用“更新数据库 删除缓存”策略。

读写缓存:需要在缓存中对数据进行增删改查,即使用“更新数据库 更新缓存”策略。

(一)针对只读缓存(更新数据库 删除缓存)

只读缓存:新增数据时,直接写入数据库;更新(修改/删除)数据时,先删除缓存。后续访问这些增删改的数据时,会发生缓存缺失,进而查询数据库,更新缓存。

mysql和redis怎么保证数据一致,mysql怎样与redis保持一致性的(1)

在更新数据的过程中,可能会有如下问题:

因此,要想达到数据一致性,需要保证两点:

接下来,我们针对有/无并发场景,进行分析并使用不同的策略。

无并发请求下,在更新数据库和删除缓存值的过程中,因为操作被拆分成两步,那么就很有可能存在“步骤1成功,步骤2失败” 的情况发生(由于单线程中步骤1和步骤2是串行执行的,不太可能会发生 “步骤2成功,步骤1失败” 的情况)。

(1) 先删除缓存,再更新数据库

mysql和redis怎么保证数据一致,mysql怎样与redis保持一致性的(2)

(2) 先更新数据库,再删除缓存

mysql和redis怎么保证数据一致,mysql怎样与redis保持一致性的(3)

mysql和redis怎么保证数据一致,mysql怎样与redis保持一致性的(4)

首页 12345下一页

栏目热文

文档排行

本站推荐

Copyright © 2018 - 2021 www.yd166.com., All Rights Reserved.