Redis学习笔记-缓冲区需要注意的问题

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis学习笔记-缓冲区需要注意的问题

Redis 中缓冲区是用一块内存空间来暂时存放命令数据,以免出现因为数据和命令处理的速度慢于发送速度而导致的数据丢失和性能问题,而当缓冲区占用的内存超出了设定的上限时,就会出现缓冲区溢出,这篇文章学习一下 Redis 中分别有哪些地方用到了缓冲区,了解其原理之后就可以合理地设置缓冲区了。

1.笔记图

2.和客户端相关的缓冲区

2.1 输入缓冲区

  • 输入缓冲区会先把客户端发送的命令暂存起来,Redis 主线程再从中读取命令处理
  • 输入缓冲区溢出:
  • 可能原因:写入了大量的 bigkey,比如短时间内写入了百万级别的集合类型数据,服务端处理请求的速度过慢,如 Redis 主线程出现了间歇性阻塞,无法及时处理正常发送的请求,导致客户端发送的请求在缓冲区越积越多
  • 如何查看CLIENT LIST 命令
CLIENT LIST
 id=4 addr=127.0.0.1:56652 fd=8 name= age=534 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=26 qbuf-free=32742 obl=0 oll=0 omem=0 events=r cmd=client user=default
  id=5 addr=127.0.0.1:56654 fd=9 name= age=500 idle=19 flags=O db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=0 oll=0 omem=0 events=r cmd=monitor user=default

Tips:cmd 表示客户端最新执行的命令,qbuf 表示输入缓冲区已经使用的大小(单位:字节),qbuf-free 表示输入缓冲区尚未使用的大小(单位:字节)。

  • 多客户端
  • 多个客户端连接占用的内存总量,超过了 Redismaxmemory 配置项时(例如 4GB),就会触发 Redis 进行数据淘汰
  • 如果使用多个客户端,导致 Redis 内存占用过大,也会导致内存溢出(out-of-memory)问题,进而会引起 Redis 崩溃,给业务应用造成严重影响
  • 应对方法
  • Redis 的客户端输入缓冲区大小的上限阈值,代码中固定设置为 1GB,无法通过配置设置调大,这个大小对于处理绝大部分客户端的请求已经够用了
  • Redis 并没有提供参数让我们调节客户端输入缓冲区的大小,要避免输入缓冲区溢出,只能从数据命令的发送速度入手,尽量避免客户端写入 bigkey

2.2 输出缓冲区

  • Redis 的输出缓冲区暂存的是 Redis 主线程要返回给客户端的数据,一部分是一个大小为 16KB 固定缓冲空间,用来暂存 OK响应和报错信息,另一部分是一个可以动态增加的缓冲空间,用来暂存大小可变的响应结果
  • 输出缓冲区溢出:
  • 可能原因
  • 服务端返回大量的 bigkeybigkey 原本就会占用大量的内存空间,所以服务器端返回的结果包含 bigkey,必然会影响输出缓冲区
  • 执行了 MONITOR 命令:该命令是用来监测 Redis 执行的,MONITOR 的输出结果会持续占用输出缓冲区,并越占越多,最后的结果就是发生溢出
MONITOR
1600617456.437129 [0 127.0.0.1:50487] "COMMAND"
1600617477.289667 [0 127.0.0.1:50487] "info" "memory"
  • 缓冲区大小设置不合理
  • 应对方法
  • MONITOR 命令主要用在调试环境中,不要在线上生产环境中持续使用 MONITOR 命令,在线上环境中偶尔使用 MONITOR 检查 Redis 的命令执行情况是没问题的
  • 通过 client-output-buffer-limit 配置项,来设置缓冲区的大小,设置缓冲区大小的上限值,设置输出缓冲区持续写入数据的数量上限阈值,和持续写入数据的时间的上限阈值
  • 配置 client-output-buffer-limit normal 0 0 0,其中 normal 表示当前设置的是普通用户,第 10 设置的是缓冲区大小的限制(0 表示不做限制),第 20 表示缓冲区持续写入量限制(0 表示不限制),第 30 表示持续写入时间限制(0 表示不限制)
  • 配置 client-output-buffer-limit pubsub 8mb 2mb 60,其中 pubsub 表示当前是对订阅客户端进行设置,8mb 表示输出缓冲区的大小上限为 8MB,超过此值服务器端就会直接关闭客户端的连接,2mb 60 表示如果连续 60 秒内对输出缓冲区的写入量超过 2MB 的话,服务器端也会关闭客户端连接

3.主从集群缓冲区

3.1 复制缓冲区

  • 主节点上会为每个从节点都维护一个复制缓冲区,来保证主从节点间的数据同步
  • 在全量复制过程中,主节点在向从节点传输 RDB 文件的同时,会继续接收客户端发送的写命令请求
  • 这些命令就会先保存在复制缓冲区中,等 RDB 文件传输完成后,再发送给从节点去执行

3.2 复制缓冲区溢出

  • 如果在全量复制的时,从节点接收和加载 RBD 较慢,同时主节点接收到了大量的写命令,写命令在复制缓冲区中就会越积越多,最终导致溢出
  • 复制缓冲区一旦发生溢出,主从节点也会直接关闭和从节点进行复制操作的连接,导致全量复制失败
  • 可以控制主节点保存的数据量大小,按通常的使用经验,我们会把主节点的数据量控制在 2~4GB,这样可以让全量同步执行得更快些,避免复制缓冲区累计过多命令
  • 可以使用 client-ouput-buffer-limit 配置项,来设置合理的复制缓冲区大小,设置的依据,就是主节点数据量大小,还有主节点的写负载压力和主节点本身的内存大小
  • 配置 config set client-output-buffer-limit slave 512mb 128mb 60,其中 slave 表示该配置是针对复制缓冲区的,512mb 表示将缓冲区大小的上限设置为 512MB128mb 60 表示如果连续 60 秒内写入的量超过 128MB 的话,也会触发缓冲区溢出

3.3 复制积压缓冲区溢出

  • 增量复制时使用的缓冲区称为复制积压缓冲区
  • 复制积压缓冲区是一个大小有限的环形缓冲区
  • 当主节点把复制积压缓冲区写满后,会覆盖缓冲区中的旧命令数据,如果主从节点还没有同步这些旧命令数据,就会造成主从节点间重新开始执行全量复制
  • 设置 repl_backlog_size 可以设置环形缓冲区大小
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
缓存 NoSQL 网络协议
Redis缓冲区不会还有人不知道吧?
缓冲区,用一块内存空间暂时存放命令数据,以免因 数据和命令的处理速度<发送速度 而导致数据丢失和性能问题。但缓冲区的内存空间有限,若持续:
429 0
|
缓存 NoSQL Redis
redis灵魂拷问:聊一聊主从复制缓冲区
redis灵魂拷问:聊一聊主从复制缓冲区
456 2
redis灵魂拷问:聊一聊主从复制缓冲区
|
4天前
|
缓存 监控 NoSQL
Redis--缓存击穿、缓存穿透、缓存雪崩
缓存击穿、缓存穿透和缓存雪崩是Redis使用过程中可能遇到的常见问题。理解这些问题的成因并采取相应的解决措施,可以有效提升系统的稳定性和性能。在实际应用中,应根据具体场景,选择合适的解决方案,并持续监控和优化缓存策略,以应对不断变化的业务需求。
56 29
|
18天前
|
缓存 NoSQL Java
Redis应用—8.相关的缓存框架
本文介绍了Ehcache和Guava Cache两个缓存框架及其使用方法,以及如何自定义缓存。主要内容包括:Ehcache缓存框架、Guava Cache缓存框架、自定义缓存。总结:Ehcache适合用作本地缓存或与Redis结合使用,Guava Cache则提供了更灵活的缓存管理和更高的并发性能。自定义缓存可以根据具体需求选择不同的数据结构和引用类型来实现特定的缓存策略。
Redis应用—8.相关的缓存框架
|
14天前
|
存储 缓存 NoSQL
Redis缓存设计与性能优化
Redis缓存设计与性能优化涵盖缓存穿透、击穿、雪崩及热点key重建等问题。针对缓存穿透,可采用缓存空对象或布隆过滤器;缓存击穿通过随机设置过期时间避免集中失效;缓存雪崩需确保高可用性并使用限流熔断组件;热点key重建利用互斥锁防止大量线程同时操作。此外,开发规范强调键值设计、命令使用和客户端配置优化,如避免bigkey、合理使用批量操作和连接池管理。系统内核参数如vm.swappiness、vm.overcommit_memory及文件句柄数的优化也至关重要。慢查询日志帮助监控性能瓶颈。
44 9
|
9天前
|
消息中间件 缓存 NoSQL
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
|
3月前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
215 85
|
1月前
|
缓存 NoSQL 中间件
Redis,分布式缓存演化之路
本文介绍了基于Redis的分布式缓存演化,探讨了分布式锁和缓存一致性问题及其解决方案。首先分析了本地缓存和分布式缓存的区别与优劣,接着深入讲解了分布式远程缓存带来的并发、缓存失效(穿透、雪崩、击穿)等问题及应对策略。文章还详细描述了如何使用Redis实现分布式锁,确保高并发场景下的数据一致性和系统稳定性。最后,通过双写模式和失效模式讨论了缓存一致性问题,并提出了多种解决方案,如引入Canal中间件等。希望这些内容能为读者在设计分布式缓存系统时提供有价值的参考。感谢您的阅读!
135 6
Redis,分布式缓存演化之路
|
2月前
|
存储 缓存 NoSQL
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应

热门文章

最新文章