Redis 大/热Key故障处理流程

一、背景

应用持续访问又大又热的key,会造成Redis实例CPU高、流量被打满、数据在内存积压,甚至导致实例达到配额限制被oom-kill。在异步调用、pipeline、mget等批量调用场景比较常见。

大key分为两种情况

  • 集合元素多且全量获取集合数据:命令时间复杂度是O(N),持续访问这样的key会导致CPU打满,业务响应变慢,甚至超时。而且响应得不到及时发送,积压在内存,最终触发oom-kill。
  • value占用内存大:持续访问这样的key会导致响应不过来(很小的请求也会造成较大的响应),从而造成返回给客户端的数据积压在Server内存,最终触发oom-kill。

二、如何发现问题

Redis集群侧会收到端口阻塞、客户端缓冲区高、实例内存高报警,推测可能是大/热key。

应用侧看到Redis服务性能变差、甚至出现大量超时。

三、问题处理过程

1、Redis侧关闭集群Failover

Redis值班同学收到告警后,会关闭该集群的自动failover,避免该分片上所有副本被打死导致数据丢失。同时会第一时间联系业务研发,双方一起定位出问题的key

2、研发和Redis侧一起定位出问题的key

Redis侧:抓包(大key导致命令阻塞,只能抓包分析)、热key扫描工具

业务研发侧:日志等信息

3、选择一种合适的方式处理key

确认导致问题的key后,可以选择下面三种方式任意一种进行处理

1、对key限流(需要应用侧具备按照key限流能力)

2、在Redis客户端开启本地缓存

3、删除key或者将key设置成一个很小的值(需要权限,对业务有影响,key设置成小值,可以避免数据回源打挂数据库)

4、处理key完成后同步给Redis侧,JIMDB侧开启集群自动Redis,恢复服务

如果原来的主实例被打死,此时会自动Failover,Failover完成后业务恢复访问。

相关推荐

  1. Redis /Key故障处理流程

    2023-12-29 16:04:04       62 阅读
  2. Redis keykey问题及处理

    2023-12-29 16:04:04       41 阅读
  3. 一文了解如何发现并解决Rediskeykey问题

    2023-12-29 16:04:04       61 阅读
  4. websocket消息处理失败排查(rediskey

    2023-12-29 16:04:04       36 阅读
  5. Rediskey问题

    2023-12-29 16:04:04       30 阅读
  6. rediskey优化

    2023-12-29 16:04:04       23 阅读
  7. 如何解决RedisKey问题?

    2023-12-29 16:04:04       68 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-29 16:04:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-29 16:04:04       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-29 16:04:04       82 阅读
  4. Python语言-面向对象

    2023-12-29 16:04:04       91 阅读

热门阅读

  1. SpringBoot--自定义starter

    2023-12-29 16:04:04       49 阅读
  2. 工作纪实40-使用redis的几种姿势

    2023-12-29 16:04:04       58 阅读
  3. R语言【base】——file.path() 构建文件路径

    2023-12-29 16:04:04       63 阅读
  4. Python 中的 DataFrame 对象该怎么理解?

    2023-12-29 16:04:04       57 阅读
  5. docker 使用

    2023-12-29 16:04:04       54 阅读
  6. docker学习(二十二、终篇,docker-compose)

    2023-12-29 16:04:04       47 阅读
  7. 9、ES高频面试题

    2023-12-29 16:04:04       58 阅读
  8. 编程笔记 html5&css&js 003 协作、约定与标准

    2023-12-29 16:04:04       44 阅读
  9. 【Linux命令】字符串搜索grep,less介绍

    2023-12-29 16:04:04       54 阅读