在删除缓存的时候,我们在一些场景下必要批量删除,但不确定具体的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用法内容请搜索草根技术分享从前的文章或继承欣赏下面的相关文章渴望大家以后多多支持草根技术分享! |