10.Redis 渐进式遍历

Redis 渐进式遍历

渐进式遍历

keys 命令一次性的把整个redis中所有的key都获取到,keys *但这个操作比较危险,可能会一下子得到太多的key,阻塞 redis 服务器。

通过渐进式遍历,就可以做到,既可以获取到所有的 key,同时又不会卡死服务器

不是一个命令,把所有的 key 都拿到,而是每执行一次命令,只获取到其中的一部分,这样的话就能保证当前这一次操作不会太卡。若要得到所有的 key 就需要多次遍历,即多次执行渐进式遍历命令。

  • SCAN:用于遍历集合中的所有元素,可以使用游标来分批获取结果。
  • ZSCAN:用于遍历有序集合中的所有元素,可以使用游标来分批获取结果。
  • HSCAN:用于遍历哈希表中的所有字段和值,可以使用游标来分批获取结果。
  • SSCAN:用于遍历集合中的所有元素,可以使用游标来分批获取结果。

由于其他的使用方法的都是相同的,下面只讲解 scan。

scan

语法:
SCAN cursor [MATCH pattern] [COUNT count] [TYPE type]

  • cursor 不能理解成下标,不是一个 连续递增 的整数,其仅仅就是一个"字符串",一开始将 cursor 设置成 0了,意味着这次遍历是从头开始获取的,其中如下图返回值 1) 旁边的数字就是告诉你,下次继续遍历时,光标要设置的值。
  • MATCH 指的就是通配符。
  • COUNT 限制这一次遍历能够获取到多少个元素,默认是10。此处的 count 只是给 redis 服务器一个 提示/建议。 写入的 count 和 实际返回的key的个数不一定是完全相同的,但是不会差很多,且每次遍历count的数字可以随便更改,每次遍历可以不同~
  • TYPE 指定只获取到 那种 value类型的 key


取出完整数据示例:

渐进性遍历 scan 虽然解决了阻塞的问题,但如果在遍历期间键有所变化(增加、修改、删除),可能导致遍历时键的重复遍历或者遗漏,这点务必在实际开发中考虑。相当于c++中的stl 的迭代器失效问题。

相关推荐
程序员三明治31 分钟前
选 Redis Stream 还是传统 MQ?队列选型全攻略(适用场景、优缺点与实践建议)
java·redis·后端·缓存·rocketmq·stream·队列
xrkhy5 小时前
微服务之ShardingSphere
数据库·微服务·oracle
JIngJaneIL6 小时前
停车场管理|停车预约管理|基于Springboot的停车场管理系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·停车场管理系统
煎蛋学姐6 小时前
SSM儿童福利院管理系统ys9w2d07(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·ssm 框架·儿童福利院管理系统
sg_knight6 小时前
MySQL 空间索引(SPATIAL)详解:地理位置数据的高效查询利器
数据库·mysql·database·索引·关系型数据库·空间索引·spatial
梦子yumeko7 小时前
第五章Langchain4j之基于内存和redis实现聊天持久化
数据库·redis·缓存
IndulgeCui8 小时前
【金仓数据库产品体验官】KSQL Developer Linux版安装使用体验
linux·运维·数据库
半旧夜夏8 小时前
【分布式缓存】Redis持久化和集群部署攻略
java·运维·redis·分布式·缓存
一马平川的大草原8 小时前
基于n8n实现数据库多表数据同步
数据库·数据同步·dify·n8n
老华带你飞10 小时前
商城推荐系统|基于SprinBoot+vue的商城推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·商城推荐系统