Redis中KEYS和SCAN命令的区别和建议

当我们需要遍历redis所有key或者指定模式的key时,首先想到的是KEYS命令,例如:keys *

成都创新互联主要从事成都网站设计、网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务丹凤,10余年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:028-86922220

相当于关系型数据库里的select *,因此在一个生产环境中的大Redis数据库中使用这个命令可能会造成性能问题。

从Redis2.8版本以后官方给我们提供了一个更好的遍历KEY的命令SCAN

语法为:

SCAN cursor [MATCH pattern] [COUNT count]

例如:

127.0.0.1:6379> scan 0 match *192.168*

1) "105"

2) 1) "192.168.0.220:6379:CommandCountByMinute"

   2) "192.168.0.121:6379:memory"

   3) "192.168.0.213:6379:CommandCount:1528190604"

   4) "192.168.0.221:6379:KeyCount:1528190601"

   5) "192.168.0.226:6379:KeyCount:1528190334"

   6) "192.168.0.129:6379:CommandCount:1528121363"

   7) "192.168.0.129:6379:KeyCount:1528121366"

SCAN 命令返回的每个元素都是一个数据库键,该命令对数据库的性能影响比较小,因此推荐在生产环境中使用。


网站标题:Redis中KEYS和SCAN命令的区别和建议
文章链接:http://bzwzjz.com/article/gshcpp.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 重庆网站设计 网站建设 成都网站设计 企业网站制作 营销型网站建设 成都网站制作 成都商城网站建设 网站建设方案 成都网站建设 响应式网站设计 网站设计制作报价 网站设计 成都定制网站建设 移动网站建设 四川成都网站设计 高端网站建设 成都网站建设 成都网站建设 古蔺网站建设 成都网站制作 成都网站建设 重庆网站建设