redis实现批量删除的命令介绍

redis实现批量删除的命令介绍

redis实现批量删除:

1、访问redis根目录    cd  /usr/local/redis-2.8.19

2、登录redis:redis-cli -h 127.0.0.1 -p 6379 (其中,127.0.0.1可以写成服务器的IP地址,6379为端口号)

3、查看所有key值:keys *

4、删除指定索引的值:del key

5、清空整个 Redis 服务器的数据:flushall 

6、清空当前库中的所有 key:flushdb 

【第一种方式】:

下面是批量删除以“key_”开头的所有redis数据 数量为100个

redis-cli -h (IP地址) -p 6379 (端口号:6379) KEYS key_* | xargs redis-cli (-h (IP地址) -p 6379 (端口号:6379)) del  =>[执行后返回的结果影响数量]:(integer) 100[数量100个]

登录后复制

【上述命令中 DEL函数的具体用法】:

DEL key [key …]

删除给定的一个或多个 key 。

不存在的 key 会被忽略。

时间复杂度:

O(N), N 为被删除的 key 的数量。

删除单个字符串类型的 key ,时间复杂度为O(1)。

删除单个列表、集合、有序集合或哈希表类型的 key ,时间复杂度为O(M), M 为以上数据结构内的元素数量。

返回值: 

被删除 key 的数量。

【举例说明】:

#  删除单个 keyredis> SET name huangzOK redis> DEL name(integer) 1 # 删除一个不存在的 keyredis> EXISTS phone(integer) 0 redis> DEL phone # 失败,没有 key 被删除(integer) 0 # 同时删除多个 keyredis> SET name "redis"OK redis> SET type "key-value store"OK redis> SET website "redis.com"OK redis> DEL name type website(integer) 3

登录后复制

【第二种方式】: 

第一种方式弊端:这样一个坏处每次都要建立一个连接,量小的话还可以接受,量大的话,效率不行。

通过内置的 Lua 解释器,可以使用 EVAL 命令对 Lua 脚本:

redis-cli -h(IP地址) -p 6379(端口号:6379) --EVAL "return redis.call('del', unpack(redis.call('keys', ARGV[1])))" 0 'Volume:*'

登录后复制

【注】:但这种处理方式,量大的情况下,lua函数unpack会出现问题,会报错误 

'''(error) ERR Error running script (call to f_e177a091510d969af3b388ee986dbe6658df6b57): @user_script:1: user_script:1: too many results to unpack'''

登录后复制

【第二种方式优化后】:

【注释】:首先定义一个数组 keys,里面存储了模式匹配的所有的以 ‘Volume:’的key,然后for循环,每次处理5000个key,也就是说每次del 5000个key

redis-cli -h(IP地址) -p 6379(端口号:6379) --EVAL "local keys = redis.call('keys', ARGV[1]) for i=1,#keys,5000 do redis.call('del', unpack(keys, i, math.min(i+4999, #keys))) end return #keys" 0 'Volume:*'

登录后复制

【第二种方式弊端】: 

KEYS操作在线上是禁止使用的!

Redis是单线程的,如果量很大的话,keys是遍历key的,会导致阻塞,这样其他的客户端就没法连接了!

【第三种方式】: 

自从redis2.8以后就开始支持scan命令,模式匹配可以采取下面的形式来批删除大量的key

redis-cli -a youpassowrd -n 0 -p 6379 --scan --pattern "Volume:*" | xargs -L 5000 redis-cli -a youpassword -n 0 -p 6379 DEL

登录后复制

【结果】:

''' /work/app/redis/bin/redis-cli -a youpassword -n 0 -p 6379 --scan --pattern "Volume:*" | xargs -L 5000 /work/app/redis/bin/redis-cli -a youpassword -n 0 -p 6379 DEL(integer) 5000(integer) 5000(integer) 5000(integer) 5000(integer) 5000(integer) 5000(integer) 5000(integer) 207'''

登录后复制

更多redis知识请关注redis入门教程栏目。

以上就是redis实现批量删除的命令介绍的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2043795.html

(0)
上一篇 2025年2月24日 00:59:54
下一篇 2025年2月24日 01:00:31

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Dubbo 配置中端口、注册中心和属性的常见问题解答

    理解 Dubbo 配置中的端口、注册中心和属性 本文旨在解答以下关于 Dubbo 配置文件中常见元素的疑问: 1. registry 中的 protocol 和外部的 protocol 的区别 Dubbo 配置文件中的 registry 标…

    2025年3月14日
    200
  • swoole自学入门教程

    Swoole是一种PHP Web服务器和应用程序框架,具有高性能和协程化特质。通过本教程,你可以了解到如何在PHP中安装和使用Swoole,包括创建HTTP服务器、使用协程和实现WebSocket通信。此外,Swoole还提供了数据库连接池…

    2025年3月13日
    200
  • workerman手册

    Workerman是一个异步事件驱动框架,用于开发高性能网络应用。其特点包括高性能、低内存消耗、易于使用和可扩展。它广泛应用于即时通讯、WebSocket服务、高并发HTTP服务等场景。使用时可创建Worker类,并调用run()函数运行W…

    2025年3月13日
    200
  • laravel8 的优化点

    Laravel 8 针对性能优化提供了以下选项:缓存配置:使用 Redis 缓存驱动、缓存门面、缓存视图和页面片段。数据库优化:建立索引、使用查询范围、使用 Eloquent 关系。JavaScript 和 CSS 优化:使用版本控制、合并…

    2025年3月13日
    200
  • 如何高效持久化多个客户端连续上传的坐标轨迹数据?

    应对海量坐标轨迹数据持久化挑战 本文探讨如何高效持久化多个客户端连续上传的坐标轨迹数据,并提供两种方案以应对不同场景的需求。 方案一:字符串拼接法(适用于轨迹较短的场景) 此方案将每秒接收到的坐标数据拼接成一个字符串,然后存储到数据库。 然…

    2025年3月13日
    200
  • Linux平台Swagger性能如何优化

    提升Linux平台Swagger性能,需要多方面策略协同。本文将介绍几种常见的优化方法: 一、硬件资源升级 内存扩容: 更大的内存直接提升Swagger响应速度。CPU升级: 更强大的CPU能更快处理请求。SSD硬盘: SSD的I/O性能远…

    2025年3月13日
    200
  • Linux上Swagger工具使用有哪些技巧

    本文介绍在Linux系统下提升Swagger工具使用效率和安全性的实用技巧。 保持Swagger版本更新: 使用最新稳定版Swagger,例如Springfox的最新版本,以确保最佳性能和安全性。 增强安全性:密码保护与身份验证: 为Swa…

    2025年3月13日
    200
  • 常用linux命令有哪些

    Linux常用命令大全 最近都在和Linux打交道,感觉还不错。我觉得Linux相比windows比较麻烦的就是很多东西都要用命令来控制,当然,这也是很多人喜欢linux的原因,比较短小但却功能强大。我将我了解到的命令列举一下,仅供大家参考…

    2025年3月13日
    200
  • macos系统查看端口和杀死进程的命令是什么

    具体命令如下所示: lsof命令可以列举出所有占用的端口列表: lsof 登录后复制 使用less分页查询 lsof | less 登录后复制 查看 sudo lsof -i:port(端口号) 登录后复制 例如: sudo lsof -i…

    2025年3月13日
    200
  • yii2项目中如何使用redis

    想要在Yii2这个PHP框架中很好的使用redis键值存储,那么首先就要推荐yii2-redis这个官方的Github库。这个库能够很好的帮助我们在Yii2框架中使用redis,它提供缓存,Session以及ActiveRecord模式的支…

    2025年3月13日
    200

发表回复

登录后才能评论