iis服务器助手广告
返回顶部
首页 > 资讯 > 数据库 >Redis如何解决BigKey
  • 392
分享到

Redis如何解决BigKey

RedisBigKey 2024-01-29 22:01:40 392人浏览 安东尼
摘要

目录一 面试题引入二 MoreKey案例2.1 大批量往Redis里面插入2000W测试数据key2.2 key *2.3 生产上如何限制keys*/flushdb/flushall等危险命令以防止误删误用?2.4 不用

面试题引入

  • 阿里广告平台,海量数据里查询某一固定前缀的key。
  • 小红书,你如何在生产上限制keys * / flushdb / flushall等危险命令以防止误删误用?
  • 美团:MEMORY USAGE 命令你用过吗?
  • BigKey 问题,多大算big,如何发现,如何删除,如何处理?
  • BigKey 你做过调优吗?惰性释放lazyfree了解过吗?
  • Morekey问题,生产上redis数据库有1000W记录,该如何遍历?key*可以吗?

二 MoreKey案例

2.1 大批量往redis里面插入2000W测试数据key

2.1.1 linux Bash下执行,插入100W

for((i=1;i<=100*10000;i++)); do echo "set K$i V$i" >> /tmp/redisTest.txt ; done; 

2.1.2 通过redis提供的管道 --pipe命令插入100W大批量数据

cat /tmp/redisTest.txt | /opt/redis-7.0.0/src/redis-cli -h 127.0.0.1 -p 6379 -a 111111 --pipe

2.2 key *

key * 这个指令有致命的弊端,在实际环境中最好不要使用

这个指令没有offset、limit参数,是要一次性吐出所有满足条件的key,由于redis是单线程的,其所有操作都是原子的,而keys算法是遍历算法,复杂度是O(n),如果实例中有千万级以上的key,这个指令就会导致Redis服务卡顿,所有读写Redis的其它的指令都会被延后甚至会超时报错,可能会引起缓存雪崩甚至数据库宕机。

2.3 生产上如何限制keys*/flushdb/flushall等危险命令以防止误删误用?

通过配置设置禁用这些命令,redis.conf在SECURITY这一项中:

Redis如何解决BigKey

2.4 不用keys * 不满卡顿,那该用什么?

2.4.1 scan命令

类似Mysql limit ,但不完全相同。
Redis SCAN命令及其相关命令 SSCAN,HSCAN,ZSCAN命令都是用于增量遍历集合中的元素。

  • SCAN:用于迭代当前数据库中的数据库键
  • SSCAN:用于迭代集合键中的元素
  • HSCAN:用于迭代哈希键中的键值对
  • ZSCAN:用于迭代有序集合中的元素(包括元素成员和元素分值)

2.4.2 scan命令用于迭代数据库中的数据库键

redis SCAN 命令基本语法如下:

SCAN cousor [MATCH pattern] [COUNT count]
  • cursor:游标
  • pattern:匹配的模式
  • count:指定从数据集里返回多少元素,默认值是10

Redis如何解决BigKey

基于游标的迭代器,需要基于上一次的游标延续之前的迭代过程以0作为游标开始一次新的迭代,直到命令返回游标0完成一次遍历,不保证每次执行都返回某个给定数量的元素,支持模糊查询。一次返回的数量不可控,只能是大概率符合count参数。

  • SCAN命令是一个基于游标的迭代器,每次被调用之后,都会想用户返回一个新的游标,用户在下次迭代时需要使用这个新游标作为SCAN命令的游标参数,以此来延续之前的迭代过程。
  • SCAN返回一个包含两个元素的数组
    • 第一个元素:用于进行下一次迭代的新游标
    • 第二个元素:是一个数组,这个数组中包含了所有被迭代的元素。如果新游标返回零表示迭代已结束。

SCAN的遍历顺序:非常特别,它不是从第一维数组的第零位一直遍历到末尾,而是采用了高位进位加法来遍历,之所以使用这样特殊的方式进行遍历,是考虑到字典的扩容和缩容时避免槽位的遍历重复和遗漏。

三 BigKey

3.1 多大算Big

拒绝bigkey(防止网卡流量,慢查询)
string类型控制在10KB以内,hash、list、set、zset元素个数不要超过5000。
字符串的bigkey,不要使用del删除,使用hscan、sscan、zscan方式渐进式删除,同时要注意防止bigkey过期时间自动删除问题(例如一个200万的zset设置1小时过期,会触发del操作,造成阻塞,而且该操作不会出现在慢查询中(latency可查))。

  • string和二级结构
    • string是value,最大512MB 但是大于10KB就是bigkey。
    • list/hash/set和zset,个数超过5000就是bigkey 

      Redis如何解决BigKey

3.2 bigkey的危害

  • 内存不均,集群迁移困难
  • 超时删除,大key删除作梗
  • 网络流量阻塞

3.3 如何产生

  • 社交类:典型案例粉丝逐步递增
  • 汇总统计:某个报表,月日年的积累

3.4 如何发现

  • redis-cli --bigkeys

    • 好处:给出每种数据结构Top 1 bigkey,同时给出每种数据类型的键值个数 + 平均大小
    • 不足:想查询大于10KB的所有key,–bigkeys参数就无能为力了。需要用到memory usage来计算每个键值的字节数

Redis如何解决BigKey

Redis如何解决BigKey

  • MOMROY USAGE :给出一个key和它的值在RAM中所占用的字节数(计算每个键值的字节数)。

3.5 如何删除

非字符串的bigkey,不要使用del删除,使用hscan、sscan、zscan方式渐进式删除。

  • string:一般用del,如果过于庞大使用unlink
  • hash:使用hscan每次获取少量field-value,再使用hdel删除每个field

Redis如何解决BigKey

list:使用ltrim渐进式逐步删除,直到全部删除完成。

Ltrim对一个列表进行修剪(trim),就是说,让列表只保留指定区域内的元素,不在指定区间之内的元素都将被删除。下标0表示列表的第一个元素,以1表示列表的第二个元素,以此类推。也可以使用负数下标,以-1表示列表的最后一个元素,-2表示列表的倒数第二个元素,以此类推。
语法:LTRIM key_NAME START STOP

Redis如何解决BigKey

set:使用sscan每次获取部分元素,再使用srem命令删除每个元素

Redis如何解决BigKey

zset:使用zscan每次获取部分元素,再使用ZREMRANGEBYRANK命令删除每个元素

Redis如何解决BigKey

四 BigKey生产调优

在redis.conf配置文件LAZY FREEING相关说明:

Redis如何解决BigKey

Redis如何解决BigKey

到此这篇关于Redis如何解决BigKey的文章就介绍到这了,更多相关Redis BigKey内容请搜索编程网(www.lsjlt.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网(www.lsjlt.com)! 

您可能感兴趣的文档:

--结束END--

本文标题: Redis如何解决BigKey

本文链接: https://www.lsjlt.com/news/559249.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis如何解决BigKey
    目录一 面试题引入二 MoreKey案例2.1 大批量往Redis里面插入2000W测试数据key2.2 key *2.3 生产上如何限制keys*/flushdb/flushall等危险命令以防止误删误用?2.4 不用...
    99+
    2024-01-29
    Redis BigKey
  • Redis中的BigKey问题排查与解决思路详解
    目录摘要Big Key问题介绍Big Key问题排查使用BIGKEYS命令Debug Objectmemory usageRedis-rdb-toolsBig Key问题解决思路分割大key对象压缩直接删除总结摘要 Re...
    99+
    2023-03-31
    Redis BigKey问题 Redis BigKey
  • Redis中的BigKey问题排查与解决方法是什么
    这篇文章主要介绍“Redis中的BigKey问题排查与解决方法是什么”,在日常操作中,相信很多人在Redis中的BigKey问题排查与解决方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis中的...
    99+
    2023-07-05
  • redis如何解决死锁
    redis解决死锁的方法:从其它进程剥夺足够数量的资源给死锁进程,解除死锁状态。撤消死锁进程或撤消代价最小的进程,直至有足够的资源可用。...
    99+
    2024-04-02
  • redis锁如何解决并发
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-06-12
  • redis读写锁如何解决
    redis 不支持原生的读写锁机制。解决方案包括:第三方工具:redlock 或 rwlock;自定义解决方案:基于令牌机制:使用 read_lock 和 write_lock 键;基于...
    99+
    2024-04-20
    redis
  • redis如何解决高并发
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-06-12
  • redis如何解决key冲突
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-06-12
  • Redis中key过期如何解决
    这篇文章给大家介绍Redis中key过期如何解决,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。初步调查受影响的团队和缓存团队开始进行初步的调查。我们发现延迟增加与现在正在发生的key清...
    99+
    2024-04-02
  • redis如何解决缓存穿透
    redis通过以下方法解决缓存穿透:1. 设置默认值;2. 使用布隆过滤器;3. 使用空值缓存;4. 使用限流。这样,当查询不存在的键时,redis可以返回默认值、检查存在性或限制请求速...
    99+
    2024-04-19
    redis
  • redis缓存穿透如何解决
    缓存穿透是指恶意用户不断查询数据库中不存在的数据,导致性能下降。解决方案包括:设置默认值使用布隆过滤器采用验证码机制限流慢查询日志分析加强数据校验 Redis 缓存穿透解决方案 什么是...
    99+
    2024-04-20
    redis
  • redis集群出错如何解决
    redis集群出错的解决示例:使用redis-cli连接上redis其中一台。命令:“redis-cli -c -h xxx -p 7001”。在输入命令“cluster info”查看当前集群的状态。再使用trib的check检测的集群状...
    99+
    2024-04-02
  • Redis key-value乱码如何解决
    这篇“Redis key-value乱码如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Redis ...
    99+
    2023-06-30
  • redis无法连接如何解决
    当Redis无法连接时,可能是由于以下几个原因导致的:1. Redis服务器未启动:首先,确保Redis服务器已经启动。可以使用`r...
    99+
    2023-09-09
    redis
  • redis节点挂了如何解决
    当Redis节点挂掉时,可以采取以下几种解决方案:1. 自动故障转移:Redis Sentinel(哨兵)可以用于监控Redis节点...
    99+
    2023-08-23
    redis
  • 如何解决redis缓存穿透
    redis 缓存穿透是指不存在于缓存中的键每次都会直接查询数据库,可采取以下措施解决:1. 使用布隆过滤器快速判断键是否存在;2. 使用空值缓存缓存不存在的值;3. 应用缓存穿透保护算法...
    99+
    2024-04-20
    redis
  • Redis数据丢失如何解决
    这篇文章将为大家详细讲解有关Redis数据丢失如何解决,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是 AOF 日志?AOF(Append Only F...
    99+
    2024-04-02
  • 如何解决redis缓存雪崩
    这篇文章主要介绍如何解决redis缓存雪崩,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!redis缓存雪崩怎么解决?缓存雪崩是指在我们设置缓存时采用了相同的过期时间,导致缓存在某一时...
    99+
    2024-04-02
  • redis突然乱码如何解决
    Redis中出现乱码的情况可能有多种原因,下面是一些常见的解决方法:1. 检查Redis的字符编码设置:在Redis配置文件中,确保...
    99+
    2023-09-11
    redis
  • 如何解决redis缓存击穿
    解决 redis 缓存击穿的方法:使用分布式锁防止缓存并发查询,允许持有锁的请求获取数据并更新缓存;限流以减轻数据库压力,防止过多并发查询;缓存空值以阻止直接访问数据库,并强制稍后重试;...
    99+
    2024-04-20
    redis 异步加载 并发请求
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作