redis作为缓存,mysql的数据如何与redis进行同步呢?双写一致性

数据可以保持延迟,但是数据最终也是一致性的

1.采用了异步处理方法,当有数据更新和插入数据库的时候,放入MQ,顶一个任务监听MQ有数据就进行更新redis缓存

2.阿里提供cannal中间件,他是一个个服务,可以伪装一个mysql节点,当mysql有更新操作的时候,会监听binlog二进制日志数据,更新到redis缓存当中
数据强一致性

1.使用的readsson分布式锁,当读数据的时候添加了一个共享锁,读读不互斥,写互斥,

写的时候添加一个排他锁又称独占锁,可以读读互斥,读写互斥。这样就保证了数据和redis缓存数据一致,共享锁和排他锁 都是一把锁

排他锁底层用的redis sexnx锁,如果有就返回false,如果没有就新建

相关推荐
生产队队长1 小时前
ThinkPHP:配置Redis并使用
android·数据库·redis
致奋斗的我们1 小时前
HAProxy介绍与编译安装
linux·汇编·数据库·mysql·青少年编程·haproxy·openeurler
Mr-Apple2 小时前
MySQL的Union和OR查询
android·数据库·mysql
YGGP3 小时前
【每日八股】Redis篇(二):数据结构
数据结构·数据库·redis
hxung3 小时前
MySQL面试学习
学习·mysql·面试
Villiam_AY3 小时前
goredis常见基础命令
redis·golang
莳花微语3 小时前
使用MyCAT实现分布式MySQL双主架构
分布式·mysql·架构
he258193 小时前
centOS 7.9 安装JDK MYSQL
java·mysql·centos
iVictor4 小时前
Redis 大 Key 分析利器:支持 TOP N、批量分析与从节点优先
redis