Redis主从模式下过期数据和数据不一致

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis缓存,出现不一致的场景

1. 目录

R-C

2. Redis删除策略

2.1. 惰性删除

数据到达过期时间,并不做处理,而是等下次访问该数据时,先判断该数据是否过期,未过期,返回数据 ;发现已过期,删除该数据,返回不存在。 这种方式虽然节约 CPU 性能,发现必须删除的时候才删除。但是对内存压力很大,会出现长期占用内存的数据。

2.2. 定时删除

通过定时器,当 key 设置有过期时间,且过期时间到达时,由定时器任务立即执行对键的删除操作,虽然节约内存,到时即删除,快速释放不必要的内存,但是给 CPU 带来压力很大,均会占据 CPU ,如果遇到高峰期,会对响应 和 指令吞吐量有影响。

2.3. 内存淘汰机制

Redis 提供 6 种内存淘汰机制:

  • volatitle-lru:least recently used,从设置已过期时间的数据集中,挑选最近使用最少的数据淘汰。
  • volatitle-ttl:从设置已过期时间的数据集中挑选即将要过期数据淘汰。
  • volatitle-random:从设置已过期时间的数据集中随机任意选择数据淘汰。
  • allkeys-lru:当内存不足在键空间中,移除最近最少使用的 key。
  • allkeys-random:当内存不足在键空间中,随机任意选择数据淘汰。
  • no-eviction:禁止驱除数据,内存不足,禁止新数据写入,对新写入的操作会报错。<极端方式,真实场景下,这种策略不值得推荐>

在 4.0 后增加了两种模式:

  • volatitle-lfu(least frequently used):从设置已过期时间的数据集中移除最不经常使用的数据淘汰。
  • allkeys-lfu(least frequently used):当内存不足在键空间中,移除最不经常使用的数据淘汰。

3. 过期数据

20211115154057

有这样一种场景,应用1 向主节点写数据,并且设置失效时间。

3.1. 读取 Master

应用数据已经过期,主库的惰性删除会发生作用,主动对该数据进行删除操作,保证 客户端应用不会拿到过期的数据。

3.2. 读取 Slave

如果 读取的是 Slave 库,则有可能会拿到过期数据,一般造成这样原因有两个。

3.2.1. 版本过低

这样的场景由于 Redis 控制不住过期数据被客户端应用误读,形成数据不安全。但是 Redis 从 3.2 版本后,对此类场景的数据问题做过滤,并且返回空值。所以 如果有应用此场景,需要对 Redis 进行升级操作。

3.2.2. 过期时间设置

与过期时间设置方式有关系,一般我们采用 EXPIREPEXPIRE,都表示从执行命令那个时刻即 开始时间 开始,往后延长 ttl 时间,严重依赖于 开始时间 从什么时候算起。

20211115155642

上图描述的过程大致如下:

  • Master 在 t1 时刻写入一个带过期时间的数据,数据的有效期一直到 t3
  • 由于网络波动或者所在服务器自身执行问题,Slave 实际执行开始时间为 t2,数据有效期一直到 t5。
  • 如果客户端应用在 t3 至 t4 时间段内访问,则可能获取到过期时间。

一般此种场景解决方案就是要求 主从节点服务器NTP时间服务保持时钟同步

4. 主从不一致

20211115161513

上图描述的过程大致如下:

  • T1 时间点,主库将主键 key1 的内容改为 100,此时通过主从异步同步,从库中的 key1 会拿到该数据
  • T2 时间点,主库将主键 key1 的内容改为 200,此时由于主从之间的网络问题,或者服务器正在处理 pipline 批处理操作,无法及时同步执行。

针对上述问题,我们建议针对 Redis 部署有如下要求:

  • 主从服务器尽量部署在同一个机房,并保持服务器间的网络良好通畅
  • 监控主从库间的同步进度,通过 info replication 命令 ,查看主库接收写命令的进度信息(master_repl_offset),从库的复制写命令的进度信息(slave_repl_offset
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
6天前
|
存储 监控 负载均衡
保证Redis的高可用性是一个涉及多个层面的任务,主要包括数据持久化、复制与故障转移、集群化部署等方面
【5月更文挑战第15天】保证Redis高可用性涉及数据持久化、复制与故障转移、集群化及优化策略。RDB和AOF是数据持久化方法,哨兵模式确保故障自动恢复。Redis Cluster实现分布式部署,提高负载均衡和容错性。其他措施包括身份认证、多线程、数据压缩和监控报警,以增强安全性和稳定性。通过综合配置与监控,可确保Redis服务的高效、可靠运行。
27 2
|
6天前
|
存储 监控 NoSQL
Redis处理大量数据主要依赖于其内存存储结构、高效的数据结构和算法,以及一系列的优化策略
【5月更文挑战第15天】Redis处理大量数据依赖内存存储、高效数据结构和优化策略。选择合适的数据结构、利用批量操作减少网络开销、控制批量大小、使用Redis Cluster进行分布式存储、优化内存使用及监控调优是关键。通过这些方法,Redis能有效处理大量数据并保持高性能。
26 0
|
22小时前
|
缓存 NoSQL 中间件
【后端面经】【缓存】36|Redis 单线程:为什么 Redis 用单线程而 Memcached 用多线程?epoll、poll和select + Reactor模式
【5月更文挑战第18天】`epoll`、`poll`和`select`是Linux下多路复用IO的三种方式。`select`需要主动调用检查文件描述符,而`epoll`能实现回调,即使不调用`epoll_wait`也能处理就绪事件。`poll`与`select`类似,但支持更多文件描述符。面试时,重点讲解`epoll`的高效性和`Reactor`模式,该模式包括一个分发器和多个处理器,用于处理连接和读写事件。Redis采用单线程模型结合`epoll`的Reactor模式,确保高性能。在Redis 6.0后引入多线程,但基本原理保持不变。
8 2
|
6天前
|
存储 NoSQL 关系型数据库
【Redis】Redis的特性和应用场景 · 数据类型 · 持久化 · 数据淘汰 · 事务 · 多机部署
【Redis】Redis的特性和应用场景 · 数据类型 · 持久化 · 数据淘汰 · 事务 · 多机部署
16 0
|
6天前
|
NoSQL Redis 数据库
Redis实现数据持久性主要依赖两种机制
【5月更文挑战第15天】Redis持久化包括RDB快照和AOF日志。RDB通过定时内存数据快照生成文件,恢复速度快但可能丢失部分数据;AOF记录每次写操作,实时性好但文件大、恢复慢。混合持久化兼顾两者优点,提供数据安全与性能平衡。用户可按需选择或组合使用策略。
8 2
|
6天前
|
NoSQL API Redis
Redis源码、面试指南(3)数据对象类型编码(下)
Redis源码、面试指南(3)数据对象类型编码
11 1
|
6天前
|
负载均衡 监控 NoSQL
Redis的几种主要集群方案
【5月更文挑战第15天】Redis集群方案包括主从复制(基础,读写分离,手动故障恢复)、哨兵模式(自动高可用,自动故障转移)和Redis Cluster(官方分布式解决方案,自动分片、容错和扩展)。此外,还有Codis、Redisson和Twemproxy等工具用于代理分片和负载均衡。选择方案需考虑应用场景、数据量和并发需求,权衡可用性、性能和扩展性。
44 2
|
6天前
|
存储 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(下)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
20 1
|
6天前
|
监控 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(上)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
36 0
|
6天前
|
存储 监控 NoSQL
Redis哨兵&分片集群
Redis哨兵&分片集群
23 0