【Redis】BigKey问题

命运对每个人都是一样的,不一样的是各自的努力和付出不同,付出的越多,努力的越多,得到的回报也越多,在你累的时候请看一下身边比你成功却还比你更努力的人,这样,你就会更有动力。

导读:本篇文章讲解 【Redis】BigKey问题,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

MoreKey案例

大批量往redis里面插入100W测试数据key(管道)

  • 生成管道文件命令

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

  • –pipe命令批量插入

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

    【Redis】BigKey问题

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

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

【Redis】BigKey问题
【Redis】BigKey问题

scan命令代替了keys *,避免了查询卡顿

  • 官网

    SCAN命令官网:https://redis.com.cn/commands/scan.html

  • 定义

    类似于MSSQL的limit

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

    SCAN cursor [MATCH pattern] [COUNT count]

    • cursor -> 游标。
    • pattern -> 匹配的模式。
    • count -> 指定从数据集里返回多少元素,默认值为10。
  • 返回

    SCAN 返回一个包含两个元素的数组,

    • 第一个元素是用于进行下一次迭代的新游标
    • 第二个元素则是一个数组,这个数组中包含了所有被迭代的元素。如果新游标返回零表示迭代已结束。
  • SCAN的遍历顺序

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

  • 使用

    redis 127.0.0.1:6379> scan 0
    1) "17"
    2)  1) "key:12"
        2) "key:8"
        3) "key:4"
        4) "key:14"
        5) "key:16"
        6) "key:17"
        7) "key:15"
        8) "key:10"
        9) "key:3"
       10) "key:7"
       11) "key:1"
    redis 127.0.0.1:6379> scan 17
    1) "0"
    2) 1) "key:5"
       2) "key:18"
       3) "key:0"
       4) "key:2"
       5) "key:19"
       6) "key:13"
       7) "key:6"
       8) "key:9"
       9) "key:11"
    
    【Redis】BigKey问题

BigKey案例

多大算大key

【Redis】BigKey问题

危害

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

如何产生

  • 定时任务
  • 汇总统计
  • 社交类

如何发现 redis-cli --bigkeysmemory usage

  • redis-cli--bigkeys

    • 用法

      每隔 100 条 scan 指令就会休眠 0.1s,ops 就不会剧烈抬升,但是扫描的时间会变长

      • redis-cli -h 127.0.0.1 -p 7001 –-bigkeys -i 0.1
    • 优势

      给出每种数据结构Top 1 bigkey,同时给出每种数据类型的键值个数+平均大小

    • 不足

      想查询大于10kb的所有key,–bigkeys参数就无能为力了,需要用到memory usage来计算每个键值的字节数

      【Redis】BigKey问题
  • memory usage

    • 用法

      计算每个键值的字节数

      • MEMORY USAGE key [SAMPLES count]

如何删除->渐进式删除

  • String

    一般del,过于庞大使用unlink

  • hash

    hscan + hdel

  • list

    ltrim:除了指定区间内的元素,其他全删

    【Redis】BigKey问题
  • set

    sscan + srem

    【Redis】BigKey问题
  • zset

    zscan + zremrangebyrank

    【Redis】BigKey问题

BigKey生产调优

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

【Redis】BigKey问题
【Redis】BigKey问题

面试题

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/143926.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!