Redis【知识点】批量删除指定Key

Redis中有删除单条数据的命令DEL但是他没有批量删除多条数据的方法,那我们怎么去批量删除多条数据呢!

第一种方式

/work/app/redis/bin/redis-cli -a youpassword keys ‘Volume:*‘ | xargs  /work/app/redis/bin/redis-cli -a youpassword del

注释:

通过:keys ‘Volume‘去匹配你要删除的Key:Value条目,然后把结果传给xargs然后删除数据

如果要删除指定的Redis库加个参数即可:(-n)一般不建议在Redis中使用多库存储数据!

/work/app/redis/bin/redis-cli -a youpassword -n 0 keys ‘Volume:*‘ | xargs  /work/app/redis/bin/redis-cli -a youpassword -n 0 del

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

第二种方式

/work/app/redis/bin/redis-cli -a youpassword EVAL "return redis.call(‘del‘, unpack(redis.call(‘keys‘, ARGV[1])))" 0 ‘Volume:*‘

注释:

这样的方式,通过内置的 Lua 解释器,可以使用 EVAL 命令对 Lua 脚本
但这种处理方式,量大的情况下,lua函数unpack会出现问题,会报错误

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

优化后的第二种方式

/work/app/redis/bin/redis-cli -a youpassword 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:*‘

注释:

实际上是对第二种方式的改进,一次性unpack太多会出问题,那就干脆一次5000吧,这样就不会有问题了!

这段脚本的意思,首先定义一个数组 keys,里面存储了模式匹配的所有的以 ‘Volume:’的key,然后for循环,每次处理5000个key,也就是说每次del 5000个key。

相关脚本:http://www.cnblogs.com/luotianshuai/

注:

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

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

第三种方式

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

/work/app/redis/bin/redis-cli -a youpassowrd -n 0 -p 6379 --scan --pattern "Volume:*" | xargs -L 5000 /work/app/redis/bin/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
‘‘‘

参考晓兄博客:https://www.18188.org/articles/2016/04/06/1459930096140.html

时间: 2024-10-04 09:01:48

Redis【知识点】批量删除指定Key的相关文章

Python批量删除指定文件夹下的指定类型的文件

Python作为一种脚本语言,其非常适合文件级的各种操作.下面的代码可以批量删除指定文件夹下的全部特定类型(CSV类型)的文件. import sys, csv , operator import os import glob for i in range(0, 20): path = "C:\\Python34\\Folder_" + str(i) for infile in glob.glob( os.path.join(path, '*.csv') ): os.remove(in

批量删除指定数据库中的指定表

-- ---------------------------------------------------------------------------------------------------------- -- -- 1.查询:得到批量删除指定数据库中的指定表: -- 2.执行:将得到的结果复制下来,再重新执行: -- SELECT CONCAT( 'drop table ', table_name, '; ' ) FROM information_schema. TABLES W

redis集群批量删除指定的key

1.说明 redis集群上有时候会需要删除多个key,就必须需要登录到每个节点上,而且有可能这个key不在这个节点,这样删除起来就比较麻烦,下面提供一种便捷方式可以实现 2.查看redis集群中的master节点 首先你要确认有哪几台master节点,可以用下面命令查看: #./redis-cli  cluster nodes | grep master PS:在这里我有3台master主节点,端口都是6379 3.编写redis_del.sh脚本 #!/bin/bash redis_comm=

mysql批量删除指定前缀或后缀表

今天突然发现我们数据库中多出很多表,后缀名为"copy",预计是navicat直接拷贝导致的,然后要对这些有同样后缀名的表进行删除,假设一个一个选择会非常麻烦,表计较多,在网上找了找方法,网上主要通过sql语句来删除.自己在他的基础上写了一个php文件实现了批量删除表.事实上原理是一样的. 1.MYSQL批量删除 [1]获得批量删除的命令: Select CONCAT( 'drop table ', table_name, ';' ) FROM information_schema.t

Linux批量删除指定后缀的文件

刚才遇到一个问题:从本地文件系统上传一个文件夹至HDFS作为Hadoop程序的输入数据,但是程序报错,原因是Ubuntu针对每个.txt文件生成了.txt~备份文件,所以我要把这些备份文件批量删除然后再上传 进入文件夹所在目录,然后执行命令: [email protected]:/usr/local/hadoop/movieinput$ find . -name '*.txt~' -type f -print -exec rm -rf {} \;

Linux shell批量删除指定目录下的所有目录的编程思路

应用场景:某个目录中存放着许多软件的源码压缩包,在部署完这些软件后,一定会生成许多没用的临时目录,可以通过脚本的方式删除该目录下所有的目录.当这个目录中存在着一些特殊名字的目录时,例如这些目录中有Linux系统所不支持的特殊字符"/"(这些文件通常有可能是Windows系统所支持的)或有目录名中有空格,那批量删除这些目录就会变得困难. 问题分析与解决办法: 问题1.当前工作目录中有一些重要的目录可能不想被删除 解决办法:排除这些目录即可 问题2.需要考虑一些特殊的目录名称,诸如&quo

Redis 通配符批量删除key

问题: 线上有部分的redis key需要清理. 一. 由于Keys模糊匹配,请大家在实际运用的时候忽略掉.因为Keys会引发Redis锁,并且增加Redis的CPU占用,情况是很恶劣的, 官网说明如下: Warning: consider KEYS as a command that should only be used in production environments with extreme care. It may ruin performance when it is execu

MySQL批量删除指定前缀表

Select CONCAT( 'drop table ', table_name, ';' ) FROM information_schema.tables Where table_name LIKE 'dede_%';

批量删除指定表

SELECT CONCAT( 'drop table ', table_name, ';' ) FROM information_schema. TABLES WHERE table_schema = 'dbname' AND table_name LIKE 'sth_%'; 原文地址:https://www.cnblogs.com/codeaaa/p/9139159.html