您现在的位置是:网站首页> 编程资料编程资料
Redis不使用 keys 命令获取键值信息的方法_Redis_
2023-05-27
441人已围观
简介 Redis不使用 keys 命令获取键值信息的方法_Redis_
1. 问题来源
这个问题可能看起来很奇怪,但很多 redis 集群会有一个统一的入口,入口会作兼容 redis 命令的代理,一般出于新能考虑是禁止使用 keys 命令来获取键值信息的,但是可以通过 scan 命令来代替 keys
2. 使用 keys 的方法
127.0.0.1:6379> KEYS * 1) "_kombu.binding.test_queue" 2) "a8e620b9-e52e-3498-8a1c-448f35783058" 3) "_kombu.binding.celery"
3. 使用 scan 的方法
127.0.0.1:6379> DBSIZE (integer) 3 127.0.0.1:6379> SCAN 0 MATCH * COUNT 3 1) "5" 2) 1) "a8e620b9-e52e-3498-8a1c-448f35783058" 2) "_kombu.binding.test_queue" 3) "_kombu.binding.celery"
简单说明
SCAN 命令 (以及相关的 SSCAN/HSCAN/ZSCAN,分别用于 SET/HASH/ZSET) 用于增量式的遍历一个集合中的元素。因为其增量特性 (每次使用只返回一小部分元素),所以在生产环境中可以用来替代 KEYS 或 SMEMBERS 命令 (KEYS 或 SMEMBERS 命令可能会因为返回的元素过多而阻塞 redis)
所以在生产环境中即便 redis 服务支持 keys 命令,也应该用 scan 来代替
参考:
1. https://groups.google.com/forum/#!topic/redis-db/zZeI_PjHF_M
2. https://redis.io/commands/scan
总结
以上所述是小编给大家介绍的Redis 不使用 keys 命令获取键值信息的相关知识,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会就及时回复大家的!
相关内容
- Windows系统安装Redis的详细图文教程_Redis_
- 浅谈分布式锁的几种使用方式(redis、zookeeper、数据库)_Redis_
- 为啥懒 Redis 是更好的 Redis_Redis_
- 一次关于Redis内存诡异增长的排查过程实战记录_Redis_
- Windows环境下Redis Cluster环境搭建(图文)_Redis_
- redis的bigkey扫描脚本深入介绍_Redis_
- Centos7 Redis主从搭建配置的实现_Redis_
- 使用redis管理用户登录会话的方法_Redis_
- redis启动,停止,及端口占用处理方法_Redis_
- 解决redis服务启动失败的问题_Redis_