|
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
在删除缓存的时候,我们在一些场景下需要批量删除,但不确定具体的key值,可通过匹配的方式进行查询后删除。
但是使用keys会导致redis服务器宕机。慎用。。。
一般公司也会禁用keys等比较敏感的命令的。
所以工作中会使用scan命令来进行匹配查询- SCAN cursor [MATCH pattern] [COUNT count]
复制代码 比如- # 从游标 0 开始扫描 匹配 test1:* 的键值,一次扫描1000条
- scan 0 match test1:* count 1000
复制代码- 1) 表示下一次扫描的游标值 ,命令行显示的是字符串类型的。
- 2)表示本次扫描匹配到的键值列表
复制代码 用php代码怎么实现呢,举个例子- function getKeysByPattern($pattern)
- {
- $keysList = [];
- while(true){
- //@todo 这里的client替换为自己的redis客户端对象
- $keys = $client->scan($iterator, $pattern,1000);
- $keysList = array_merge($keysList, $keys??[]);
- if ($iterator === 0) {//迭代结束,未找到匹配pattern的key
- break;
- }
- if ($iterator === null) {//"游标为null了,重置为0,继续扫描"
- $iterator = "0";
- }
- }
- $keysList = array_unique($keysList);
- return keysList;
- }
复制代码 内容扩展
php redis扩展支持scan命令实现方法- # git clone https://github.com/phpredis/phpredis
- # cd phpredis
- # /opt/php/bin/phpize
- # ./configure --with-php-config=/opt/php/bin/php-config
- # make && make install
复制代码 到此这篇关于php redis的scan用法实例分析的文章就介绍到这了,更多相关php redis的scan用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
|