什么是Redis的大Key和热Key?项目中一般是怎么解决的?

一、首先我们要搞清楚大key和热key是什么。

1. 大Key

通常以Key的大小和Key中成员的数量来综合判定。比如Key本身的Value过大,一个String类型的Key,它的值为10 MB;Key中的成员数过多:一个ZSET类型的Key,它的成员数量为10000个。

2. 热key

通常以其接收到的Key被请求频率来判定,例如:QPS集中在特定的Key,Redis实例的总QPS为10000,而其中一个Key的每秒访问量达到了8000。

3. 导致的问题

  • 大Key一般产生的问题就是占用大量的带宽以及资源资源,导致系统出现OOM,访问阻塞等问题。
  • 热Key占用大量的CPU资源,影响其他请求并导致整体性能降低。

4. 如何找到大Key和热Key呢?

通过redis-cli的bigkeys和hotkeys参数查找大Key和热Key,当然如果有第三方监控平台也是可以的。

二、解决办法

1. 针对大key的问题

  • 我们可以对大Key进行拆分,例如将含有数万成员的一个HASH Key拆分为多个HASH Key,并确保每个Key的成员数量在合理范围。在Redis集群架构中,拆分大Key能对数据分片间的内存平衡起到显著作用。
  • 定期进行清理掉无效的key,腾出更多的内存空间。

2. 针对热Key的问题

  • 在Redis集群架构中对热Key进行复制,然后改名迁移到其他分片。例如将热Key foo复制出3个内容完全一样的Key并名为foo2、foo3、foo4,将这三个Key迁移到其他数据分片来解决单个数据分片的热Key压力。
  • 读写分离:如果热Key的产生来自于读请求,可以将实例改造成读写分离架构来降低每个数据分片的读请求压力,甚至可以不断地增加从节点。
  • 做好系统的监测,建立预警机制,提前做好防范。
相关推荐
Remember_9932 小时前
Spring 事务深度解析:实现方式、隔离级别与传播机制全攻略
java·开发语言·数据库·后端·spring·leetcode·oracle
小园子的小菜2 小时前
深入剖析HBase HFile原理:文件结构、Block协作与缓存机制
数据库·缓存·hbase
空空kkk2 小时前
SSM项目练习——hami音乐(三)
java·数据库
好奇的菜鸟2 小时前
Ubuntu 18.04 启用root账户图形界面登录指南
数据库·ubuntu·postgresql
天桥下的卖艺者2 小时前
使用R语言编写一个生成金字塔图形的函数
开发语言·数据库·r语言
廋到被风吹走2 小时前
【缓存优化】缓存穿透:布隆过滤器(Guava/RedisBloom)
缓存·guava
Facechat2 小时前
鸿蒙开发入坑篇(九):本地数据库 (RDB) 深度解析
数据库·华为·harmonyos
Dxy12393102162 小时前
MySQL删除表语句详解
数据库·mysql
编程彩机2 小时前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务