在删除缓存的时候,我们在一些场景下需要批量删除,但不确定具体的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用法内容请搜索编程界以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程界!