深入理解Redis BigKey

 更新时间:2025年02月28日 09:43:21   作者:潜水的码不二  
本文主要介绍了Redis中的BigKey问题及其处理方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

MoreKey

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

  • LinuxBash下面执行,插入100w数据脚本
# 生成100W条redis批量设置kv的语句(key=kn,value=vn)写入到/tmp目录下的redisTest.txt文件中

for((i=1;i<=100*10000;i++)); 
do echo "set k$i v$i" >> /tmp/redisTest.txt ;
done;
  • 通过Redis提供的管道–pipe命令插入100W大批量数据

结合自己机器的地址:

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

请添加图片描述

尝试keys * 花费时间

请添加图片描述

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

请添加图片描述

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

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

请添加图片描述

请添加图片描述

SCAN命令

1.语法

请添加图片描述

​ 2.特点

​ Redis Scan命令基本语法如下:

SCAN cursor [MATCH pattern] [COUNT count]

​ cursor -游标

​ pattern -匹配的模式

​ count -指定从数据集里返回多少元素,默认值为10。

SCAN 命令是一个基于游标的迭代器,每次被调用之后, 都会向用户返回一个新的游标, 用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数, 以此来延续之前的迭代过程。

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

第一个元素是用于进行下一次迭代的新游标,

第二个元素则是一个数组, 这个数组中包含了所有被迭代的元素。如果新游标返回零表示迭代已结束。

SCAN的遍历顺序

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

​ 3.使用

请添加图片描述

BigKey

多大算Big

参考《阿里云Redis开发规范》

请添加图片描述

string和二级结构

string是value,最大512MB但是≥10KB就是bigkey

list、hash、set和zset,个数超过5000就是bigkey

​ List:一个列表最多可以包含2^32-1个元素(4294967295,每个列表超过40亿个元素)。

​ hash:Redis中每个hash可以存储2^32-1键值对(40多亿)

​ set:集合中最大的成员数为2^32-1 (4294967295,每个集合可存储40多亿个成员)。

​ …

危害

1.内存不均,集群迁移困难

2.超时删除,大key删除作梗

3.网络流量阻塞

找出BigKey

redis-cli --bigkeys

好处

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

不足

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

redis-cli --bigkeys -a 111111

redis-cli -h 127.0.0.1 -p 6379 -a 111111 --bigkeys
每隔 100 条 scan 指令就会休眠 0.1s,ops 就不会剧烈抬升,但是扫描的时间会变长redis-cli -h 127.0.0.1 -p 7001 –-bigkeys -i 0.1

请添加图片描述

MEMORY USAGE 键

请添加图片描述

如何删除

请添加图片描述

String

一般用del,如果过于庞大unlink

hash

使用hscan每次获取少量field-value,再使用hdel删除每个field

请添加图片描述

请添加图片描述

list

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

请添加图片描述

请添加图片描述

set

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

请添加图片描述

Zset

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

请添加图片描述

BigKey生产调优

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

阻塞和非阻塞删除命令

请添加图片描述

优化配置

请添加图片描述

到此这篇关于深入理解Redis BigKey的文章就介绍到这了,更多相关Redis BigKey内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • 解读缓存db redis local的取舍之道

    解读缓存db redis local的取舍之道

    这篇文章主要介绍了解读缓存db redis local的取舍之道,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • Redis中Scan命令的基本使用教程

    Redis中Scan命令的基本使用教程

    这篇文章主要给大家介绍了关于Redis中Scan命令的基本使用教程,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • 简单粗暴的Redis数据备份和恢复方法

    简单粗暴的Redis数据备份和恢复方法

    这里我们来讲解一个简单粗暴的Redis数据备份和恢复方法,有一个在不同主机上迁移Redis数据的示例,还有一个备份脚本实现的关键点提示,一起来看一下:
    2016-06-06
  • Redis的持久化方案详解

    Redis的持久化方案详解

    在本篇文章里小编给大家整理的是关于Redis的持久化方案详解,有兴趣的朋友们可以参考下。
    2020-03-03
  • 详解Redis如何处理Hash冲突

    详解Redis如何处理Hash冲突

    在 Redis 中,哈希表是一种常见的数据结构,通常用于存储对象的属性,对于哈希表,最常遇到的是哈希冲突,那么,当 Redis遇到Hash冲突会如何处理?本文我们将详细介绍Redis如何处理哈希冲突,需要的朋友可以参考下
    2024-09-09
  • 利用redis lua脚本实现时间窗分布式限流

    利用redis lua脚本实现时间窗分布式限流

    Lua是一种轻量小巧的脚本语言,Redis是高性能的key-value内存数据库,在部分场景下,是对关系数据库的良好补充,本文给大家介绍了如何利用redis lua脚本实现时间窗分布式限流,需要的朋友可以参考下
    2024-03-03
  • 深入理解Redis7哨兵模式(保姆级教学)

    深入理解Redis7哨兵模式(保姆级教学)

    Redis的主从复制存在一定的缺陷,为了解决这一问题,Redis官方推荐一种高可用方案哨兵模式,本文主要介绍了深入理解Redis7哨兵模式,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • redis分布式锁实现示例

    redis分布式锁实现示例

    本文主要介绍了redis分布式锁实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-11-11
  • IDEA中的Redis插件连接Redis服务器

    IDEA中的Redis插件连接Redis服务器

    本文主要介绍了IDEA中的Redis插件连接Redis服务器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • redis实现分布式全局唯一id的示例代码

    redis实现分布式全局唯一id的示例代码

    在某些场景中,我们需要生成全局的唯一ID,本文主要介绍了redis实现分布式全局唯一id的示例代码,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04

最新评论