1. 問題來源
這個(gè)問題可能看起來很奇怪,但很多 redis 集群會(huì)有一個(gè)統(tǒng)一的入口,入口會(huì)作兼容 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 命令 (以及相關(guān)的 SSCAN/HSCAN/ZSCAN,分別用于 SET/HASH/ZSET) 用于增量式的遍歷一個(gè)集合中的元素。因?yàn)槠湓隽刻匦?(每次使用只返回一小部分元素),所以在生產(chǎn)環(huán)境中可以用來替代 KEYS 或 SMEMBERS 命令 (KEYS 或 SMEMBERS 命令可能會(huì)因?yàn)榉祷氐脑剡^多而阻塞 redis)
所以在生產(chǎn)環(huán)境中即便 redis 服務(wù)支持 keys 命令,也應(yīng)該用 scan 來代替
參考:
1. https://groups.google.com/forum/#!topic/redis-db/zZeI_PjHF_M
2. https://redis.io/commands/scan
總結(jié)
以上所述是小編給大家介紹的Redis 不使用 keys 命令獲取鍵值信息的相關(guān)知識(shí),希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)就及時(shí)回復(fù)大家的!
您可能感興趣的文章:- Redis遍歷所有key的兩個(gè)命令(KEYS 和 SCAN)
- redis keys與scan命令的區(qū)別說明
- 解決spring中redistemplate不能用通配符keys查出相應(yīng)Key的問題
- 在RedisTemplate中使用scan代替keys指令操作
- Redis的KEYS 命令千萬不能亂用
- Redis命令使用技巧之Keys的相關(guān)操作
- redis 用scan指令 代替keys指令(詳解)
- 淺談Redis的keys命令到底有多慢