详谈redis跟数据库的数据同步问题

2025-01-11 04:50

本文主要是介绍详谈redis跟数据库的数据同步问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R...

一、Redis 数据库数据一致性的解决方案

在修改数据的时候,通常面临着双写的问题,也就是redis中要更新数据,数据库中也要更新数据,对于这个问题redis、数据库的数据同步方案有四种:

  1. 先更新Redis缓存,再更新数据库
  2. 先更新数据库,再更新Redis缓存
  3. 先删除Redis中的缓存,再更新数据库
  4. 先更新数据库,在删除Redis缓存

从上面的解决方案来看,先不说Redis、数据库的操作先后,数据库的操作始终都是更新,但是Redis不一样,Redis有两种方案,一是更新(也就是直接在Redis中写入更新的数据),二是删除Redis中的缓存,那么接下来我们就看看这两者有什么区别

1.1、更新Redis缓存、删除Redis缓存的区别

更新Redis缓存

  • 优点:每次数据变化都及时更新缓存,所以查询时不容易出现未命中的情况
  • 缺点:更新缓存的消耗比较大。如果数据要经过复杂的计算再写入缓存,那么频繁的更新缓存,就会影响服务器的性能。又因为Redis是单线程的,所以如果是写入数据频繁的业务场景,那么可能频繁的更新缓存时,却没有多余的线程读取该数据。

删除Redis缓存

  • 优点:操作简单,无论更新操作是否复杂China编程,都是将缓存中的数据直接删除
  • 缺点:删除缓存后,下一次查询缓存会出现未javascript命中,这时需要重新读取一次数据库。从上面的比较来看,一般情况下,删除缓存是更有的方案

所以经过这两个区别的比较,我们只会采取删除Redis缓存的两个方案,接下来就是比较这两个方案会产生什么样的问题,哪一个方案产生的问题比较容易解决

二、先删Redis缓存、后删Redis缓存会产生什么问题?解决方案?

2.1、删除Redis缓存,再更新数据库

详谈redis跟数据库的数据同步问题

从上面的图可以知道,如果更新数据库失败的话,那么即使删除Redis缓存成功了,在重试期间,下一次读取出来的数据还是之前的旧数据,即使重试成功了,数据库的数据更新了,但是Redis中已经被重新缓存了旧数据,这样两边的数据就不会一致

2.2、解决方案

从上面的问题可以知道,问题就出现在进行修改数据库重试期间,有线程访问Redis,而www.chinasem.cn此时Redis中没有数据,就会从数据库中拿数据,而此时的数据还是旧数据,就导致Redis重新缓存了旧数据,等重试成功之后导致数据库跟Redis缓存数据不一致

编程个问题的解决方案就是采用延迟双删的方案来解决

延迟双删的主要思想就是,在数据库中的数据更新成功之后,再启动一个延时线程来删除Redis中的缓存,那么之后读取的数据就是更新后的数据了,完整的流程应该是:

  1. 先删一次Redis的缓存
  2. 更新数据库中的数据
  3. 可以使用sleep方法让线程睡一会
  4. 然后再删除一个Redis的缓存

2.3、先更新数据库,再删除Redis缓存

详谈redis跟数据库的数据同步问题

如上图,是先更新数据库再删除缓存,在出现失败时可能出现的问题:

  • 线程A更新数据库成功,线程A删除缓存失败;
  • 线程B读取缓存成功,由于缓存删除失败,所以线程B读取到的是缓存中旧的数据。
  • 最后线程A删除缓存成功,有别的线程访问缓存同样的数据,与数据库中的数据是一样。
  • 最终,缓存和数据库的数据是一致的,但是会有一些线程读到旧的数据。

这个方案编程影响就会比较小一点,可以只采取重试机制就可以解决上面的问题,但是先删除Redis缓存的那个方案不同,即使采取了重试机制过后,很有可能还是会产生数据不一致的情况,所以加了一个延迟双删的方案

比较两个方案的谁更好

先删除Redis的那个方案即使所有的操作都是成功的,但是在分布式场景下,有可能会导致高并发问题的产生,也就是说可能会在更新数据库数据的同时有线程会访问数据,这也就会导致数据不一致的问题

而先删除数据库则不一样,即使在更新数据库的时候发生了高并发问题也不影响,因为反正更新完数据库之后还是会删除Redis中的缓存,有影响的也仅仅只是在高并发产生的那部分线程而已,所以很明显第二个方案影响更小

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于详谈redis跟数据库的数据同步问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:http://www.cppcns.com/shujuku/redis/696688.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1153032

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

IDEA连接达梦数据库的详细配置指南

《IDEA连接达梦数据库的详细配置指南》达梦数据库(DMDatabase)作为国产关系型数据库的代表,广泛应用于企业级系统开发,本文将详细介绍如何在IntelliJIDEA中配置并连接达梦数据库,助力... 目录准备工作1. 下载达梦JDBC驱动配置步骤1. 将驱动添加到IDEA2. 创建数据库连接连接参数

通过ibd文件恢复MySql数据的操作方法

《通过ibd文件恢复MySql数据的操作方法》文章介绍通过.ibd文件恢复MySQL数据的过程,包括知道表结构和不知道表结构两种情况,对于知道表结构的情况,可以直接将.ibd文件复制到新的数据库目录并... 目录第一种情况:知道表结构第二种情况:不知道表结构总结今天干了一件大事,安装1Panel导致原来服务

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.

Seata之分布式事务问题及解决方案

《Seata之分布式事务问题及解决方案》:本文主要介绍Seata之分布式事务问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Seata–分布式事务解决方案简介同类产品对比环境搭建1.微服务2.SQL3.seata-server4.微服务配置事务模式1

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete