php redis的scan用法实例分析

admin3年前PHP教程58

在删除缓存的时候,我们在一些场景下需要批量删除,但不确定具体的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

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

相关文章

详解PHP服务器如何在有限的资源里最大提升并发能力

概述假设报考app是用5W rmb 向供应商采购,报名当天涌入海量考生,并发数飙升至30W+,导致系统宕机,拒绝服务,致使考生无法报名,那么5W rmb 能否支持30W+并发呢?不过对于我们来说,不妨...

法国服务器在哪里购买便宜

法国服务器在哪里购买便宜?要购买便宜的法国服务器,您可以考虑以下几个方面:比较多家供应商的价格:在网络上搜索并比较各家法国服务器提供商的价格和服务内容,找到价格合理、服务质量好的供应商。节假日或者特别...

GPU服务器和普通服务器区别租用美国显卡服务器有什么优势

GPU服务器又被称为显卡服务器,是基于GPU的应用于视频编解码、深度学习、科学计算等多种场景的快速、稳定、弹性的计算服务。GPU加速计算可以提供非凡的应用程序性能,能将应用程序计算密集部分的工作负载转...

php对数字进行万、亿单位的转化

php对数字进行万。亿的转化/** * 格式化数字 */public function float_number($number){    ...

PHP 引用的概念

目录什么是引用?引用在数组和对象中的使用引用的传递引用的返回引用的取消总结什么是引用?在 PHP 中引用意味着用不同的名字访问同一个变量内容。它不是C的指针,保存的并不是内存地址,无法进行指针运算。引...

GPU服务器应用场景租用美国gpu服务器厂家有哪些

面对庞大的数据量,我们不能要求人工计算,并且CPU不能处理大量数据集以及并行操作,此时GPU的出现帮助用户解决痛点,可以执行处理高速、实时的并行任务。因而,GPU的特性也就决定了GPU服务器的使用场景...