php redis的scan用法实例分析

admin3年前PHP教程88

在删除缓存的时候,我们在一些场景下需要批量删除,但不确定具体的key值,可通过匹配的方式进行查询后删除。

但是使用keys会导致redis服务器宕机。慎用。。。

一般公司也会禁用keys等比较敏感的命令的。

所以工作中会使用scan命令来进行匹配查询

?

1
SCAN cursor [MATCH pattern] [COUNT count]






比如

?

1
2
# 从游标 0 开始扫描 匹配 test1:* 的键值,一次扫描1000条
scan 0 match test1:* count 1000






1) 表示下一次扫描的游标值 ,命令行显示的是字符串类型的。
2)表示本次扫描匹配到的键值列表

用php代码怎么实现呢,举个例子

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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命令实现方法

?

1
2
3
4
5
# git clone http://github/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用法内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:php/php-weizijiaocheng-485532

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

香港高防服务器推荐选择什么配置好

香港高防服务器推荐选择什么配置好?选择高防服务器的配置应该根据您的具体需求和预算来决定。以下是一些常见的建议:带宽:选择足够的带宽,以确保您的网站或应用程序能够处理高流量。处理器:选择高性能的处理器,...

什么配置的日本服务器值得推荐购买

什么配置的日本服务器值得推荐购买?选择日本服务器的配置应该根据您的需求进行选择,不同的应用场景可能需要不同的服务器配置。以下是一些值得推荐购买的日本服务器配置:CPU:一般来说,使用英特尔或AMD的多...

php获取referer防非法访问

下面是我下载页面down.php 的php代码 现在我发现,用迅雷,谷歌浏览器直接打开,就能输出下载文件,一点不起防盗链作用。 现在我想,只允许在我自己站上连接过来的可以直接使用,...

美国高防服务器租用时的注意事项有哪些

租用美国高防服务器时需要注意以下事项:需要选择信誉度高、口碑好的服务商,了解服务商的资质、客户评价等方面,确保服务的可靠性和安全性。需要根据自己的需求选择合适的服务器配置、带宽、存储等服务,确保满足自...

php png失真的原因及解决办法

1、创建一个PHP示例文件。2、创建一个和背景图片一样大小的真彩色画布。3、复制背景图片。4、通过“imagecreatefrompng”合成png图片即可。实例?123456...

江苏高防服务器有哪些优势

江苏高防服务器有哪些优势?江苏高防服务器相比传统服务器具有以下优势:1.高防抗D攻击:江苏高防服务器采用了高防抗D攻击的技术,能够有效抵御各种DDoS和CC攻击,保障网络的安全稳定性。2.高性能:江苏...