“数据持久化”和“缓存与数据库不一致”到底有什么区别?

之前,我一直把"数据持久化"和"缓存与数据库不一致问题"给搞混了。我当时复习的时候基本上就没有思考,就是纯背诵,数据持久化是什么,数据持久化有两种方式,这两种方式特点是什么,然后巴拉巴拉一堆。缓存与数据库不一致问题是什么什么,怎么解决缓存与数据库不一致问题,巴拉巴拉。结果背着背着,我把自己给背懵了,这两个东西确实有点像,但是具体哪里像我也说不出来,久而久之,我的脑子就把这两个给混淆了。

究其原因,我是没有做到深度思考。我就是做一些很机械化的背诵,根本没有想过这两者的区别,没有想过以下两个问题:

1.为什么要有这门技术?

2.这门技术解决了什么问题?

首先,为什么要有数据持久化呢?也就是说数据持久化的目的是什么呢?数据持久化是防止数据宕机时数据丢失,所以要用 AOF 和 ROB 方式来对 Redis 中某时刻的数据状态进行记录。数据持久化是侧重于记录数据某时刻的状态,Redis宕机了,还可以恢复。

对于数据库和缓存不一致问题,又是另一方面的内容了。Redis有一种数据结构叫哈希,哈希是可以做缓存的,所以Redis可以做缓存。如果Redis不用来做缓存,那就根本不会有Redis与数据库不一致的情况。正是因为Redis做了缓存,导致现在读写请求都要先写Redis,再写数据库。如果写Redis和写数据库这两个操作都成功,那其实一点问题没有,但是假如有一个没有成功,那就废了,就会产生数据库和缓存不一致。数据库和缓存不一致问题我们通过调整写数据库和写缓存,或者写数据库和删除缓存的顺序先后,就可以解决数据库和缓存不一致问题。而不是像数据持久化一样采用技术的方式(AOF日志和ROB快照)解决问题。

至于这两者的具体是如何实现的,其实我已经差不多心中有数了。

数据持久化:

数据库和缓存不一致问题:

通过写这篇文章,我懂得了深度思考的重要性,它可以使得我们对知识点的理解更加透彻,而不是浮于表面,我之前对这些知识点的理解就是浮于表面,当我做到逼着自己去想以上那两个问题的时候,才能做到真正理解这个知识点,从而获得可观的进步。

相关推荐
极客先躯1 分钟前
高级java每日一道面试题-2025年9月23日-企业集成篇[LangChain4j]-如何与现有的企业中间件集成(Kafka、RabbitMQ)?
java·中间件·java-rabbitmq·稳定性·可靠性·扩展性·langchain4j
cch89181 分钟前
PHP vs Java:主流编程语言深度对比
java·开发语言·php
曹牧3 分钟前
Tomcat中间件能够提供的能力
java·中间件·tomcat
少司府3 分钟前
C++基础入门:类和对象(上)
c语言·开发语言·c++·类和对象·访问限定符
deep_drink4 分钟前
1.1、Python 与编程基础:开发环境、基础工具与第一个 Python 项目
开发语言·人工智能·python·llm
码农很忙4 分钟前
Spring Boot 3.x 整合 Redis 实现高性能缓存的完整指南
java·spring boot·redis
ANii_Aini4 分钟前
mysql数据库保姆级安装教程-mac(一站式服务,提供资源)
数据库·sql·mysql·navicat
禾小西6 分钟前
Spring AI 流式输出底层原理解析
java·人工智能·spring
云飞云共享云桌面6 分钟前
8人SolidWorks研发共享一台服务器——性能算力共享智能按需分配
运维·服务器·网络·数据库·3d·电脑
高梦轩8 分钟前
MySQL 主从复制 + 读写分离
android·数据库