温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PHP7+REDIS3.2 phpredis scan命令 游标问题

发布时间:2020-08-09 06:18:17 来源:网络 阅读:2558 作者:努力的C 栏目:web开发

redis 中匹配某些key的方法一般有keys和scan两种方式,但是鉴于直接在线上执行keys操作可能会造成Redis卡死等问题,所以想看有哪些keys,只能使用scan来操作了。在Redis命令行下操作没啥问题:
SCAN 游标 MATCH 模式 COUNT
每次执行都会返回当前遍历到了哪个槽位和是否找到了对应的key
项目中使用了Phpredis扩展,所以想着用程序来遍历一下看看,一开始按照phpredis官网文档提供的代码示例执行
:这是官方文档,我在PHP7下执行了一下,发现并没有结果。。。。。。。
scan
Description: Scan the keyspace for keys

Parameters
LONG (reference): Iterator, initialized to NULL STRING, Optional: Pattern to match LONG, Optional: Count of keys per iteration (only a suggestion to Redis)

Return value
Array, boolean: This function will return an array of keys or FALSE if Redis returned zero keys

Example

/ Without enabling Redis::SCAN_RETRY (default condition) /
$it = NULL;
do {
// Scan for some keys
$arr_keys = $redis->scan($it);

// Redis may return empty results, so protect against that
if ($arr_keys !== FALSE) {
    foreach($arr_keys as $str_key) {
        echo "Here is a key: $str_key\n";
    }
}

} while ($it > 0);
echo "No more keys to scan!\n";

/ With Redis::SCAN_RETRY enabled /
$redis->setOption(Redis::OPT_SCAN, Redis::SCAN_RETRY);
$it = NULL;

/ phpredis will retry the SCAN command if empty results are returned from the
server, so no empty results check is required.
/
while ($arr_keys = $redis->scan($it)) {
foreach ($arr_keys as $str_key) {
echo "Here is a key: $str_key\n";
}
}
echo "No more keys to scan!\n";

然后从网上搜了一下,发现有 $redis->scan($it,$match,$count)的,这样好像能搜到一些key,但还是不行。
我的理想情况是跟命令行一样,每次scan能够返回一个游标的位置和这次扫描出的keys。。。。。。。。。

最后是同事写了一个版本,这个版本可以

$it = null;
$match = 'zhongce:activity_vote*';
$count = 10000;
$index = 0;
$redis->setOption(Redis::OPT_SCAN,Redis::SCAN_RETRY);
$iterator = null;
while ($keys = call_user_func_array(array($redis, 'scan'), array(&$it, $match))) {

foreach ($keys as $key) {
    echo $key . PHP_EOL;
}

}

上面是没加count的版本,会直接遍历出所有满足条件的keys,你也可以加上count限制每次遍历的数量。。。。。。。。。。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI