Redis双写一致性

文章目录

  • Redis双写一致性
  • [1. 延迟双删(有脏数据风险)](#1. 延迟双删(有脏数据风险))
  • [2. 异步通知(保证数据最终一致性)](#2. 异步通知(保证数据最终一致性))
  • [3. 分布式锁(数据的强一致,性能低)](#3. 分布式锁(数据的强一致,性能低))

Redis双写一致性

当修改了数据库的数据也要同时更新缓存的数据,缓存和数据库的数据要保持一致。

1. 延迟双删(有脏数据风险)

  1. 先删缓存,还是先删数据库?
    无论先删缓存还是先删数据库,在多线程情况下都可能导致缓存脏数据的可能。
  2. 延迟双删(有脏数据风险)
  • 读操作:缓存命中,直接返回;缓存未命中查询数据库,写入缓存,设定超时时间
  • 写操作:延迟双删
    删除两次缓存,是为了减少缓存脏数据的可能性
    存在的问题:延迟的时间不好控制

2. 异步通知(保证数据最终一致性)

  • 基于MQ异步通知
  • 基于Canal异步通知

二进制日志(BINLOG)记录了所有DDL语句和DML语句,但不包括数据查询(select,show)语句

3. 分布式锁(数据的强一致,性能低)

读多写少 情况下可以使用分布式锁,能保证数据的强一致性,但是性能比较低

实现:

共享锁:读锁readLock,加锁之后,其他线程可以共享读操作(用在查询数据方法里面)

排他锁:独占锁writeLock,加锁之后,阻塞其他线程读写操作(用在更新数据方法里面)

使用Redisson来实现,对同一把锁分别使用readLock,writeLock。

java 复制代码
RReadWriteLock readWriteLock = redissonClient.getReadWriteLock("ITEM_READ_WRITE_LOCK");
//在更新数据的方法里面使用writeLock
readWriteLock.writeLock();
//在查询的方法使用readLock
readWriteLock.readLock();
相关推荐
一个天蝎座 白勺 程序猿4 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴4 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU4 小时前
三大范式和E-R图
数据库
一江寒逸4 小时前
零基础从入门到精通MySQL(上篇):筑基篇——吃透核心概念与基础操作,打通SQL入门第一关
数据库·sql·mysql
@土豆4 小时前
Ubuntu 22.04 运行 Filebeat 7.11.2 崩溃问题分析及解决文档
linux·数据库·ubuntu
专注API从业者4 小时前
淘宝商品详情 API 与爬虫技术的边界:合法接入与反爬策略的技术博弈
大数据·数据结构·数据库·爬虫
Devin~Y4 小时前
高并发电商与AI智能客服场景下的Java面试实战:从Spring Boot到RAG与向量数据库落地
java·spring boot·redis·elasticsearch·spring cloud·kafka·rag
爱码小白4 小时前
MySQL 单表查询练习题汇总
数据库·python·算法
WangJunXiang64 小时前
第09章:PostgreSQL日常维护
数据库·postgresql
三道渊5 小时前
进程通信与网络协议
开发语言·数据库·php