从Redis中删除大集合对象的方法
Redis中的大集合对象,如set、zset等,如果有上千万个元素,一般是不能直接用del命令来删除的,因为del命令可能会耗时几秒钟,而redis本身是单线程的,在高并发的情况下会阻塞大量的请求,严重时可能引起雪崩。
那我们要怎么来删除它呢?
这里我们给出一个解决方案,即结合lua脚本来实现删除大对象。
先写如下lua脚本,保存为test_del.lua文件。
<<test_del.lua>>
local count=redis.call('zcard', 'big_obj_key')
while count>0 do
redis.call('zremrangebyrank', ' big_obj_key', 0, 500) // 每次删除500个元素
count=redis.call('zcard', ' big_obj_key')
print("Current count: ", count)
end
最后,在命令行使用如下命令执行该lua脚本即可。
bin/redis-cli -p 6370 -a yourpasswd --eval /usr/local/redis/lua/test_del.lua
是不是很方便啊?
从Redis中删除大集合对象的方法的更多相关文章
- JavaScript从数组中删除指定值元素的方法
		本文实例讲述了JavaScript从数组中删除指定值元素的方法.分享给大家供大家参考.具体分析如下: 下面的代码使用了两种方式删除数组的元素,第一种定义一个单独的函数,第二种为Array对象定义了一个 ... 
- 【转载】C#中使用List集合的Insert方法在指定位置插入数据
		在C#的List集合等数据类型变量中,我们可以使用List集合的Insert方法在指定的索引位置插入一个新数据,例如指定在List集合的第一个位置写入一个新数据或者在List集合的中间某个位置插入个新 ... 
- redis中AOF和RDB的关闭方法
		redis中AOF和RDB的关闭方法 问题:当往redis中导入数据时,有时会出现redis server went away的情况: 原因: 导入的数据量太大,而内存不够(即内存1G,但数据有2 ... 
- ArcGIS Engine中删除要素的几种方法总结
		转自原文 ArcGIS Engine中删除要素的几种方法总结 /// <summary> /// 通过IFeature.Delete方法删除要素 /// </summary> ... 
- PHP从数组中删除元素的四种方法实例
		PHP从数组中删除元素的四种方法实例 一.总结 一句话总结:unset(),array_splice(),array_diff(),array_diff_key() 二.PHP从数组中删除元素的四种方 ... 
- javaScript中Math内置对象基本方法入门
		概念 Math 是javaScript的内置对象,包含了部分数学常数属性和数学函数方法. Math 不是一个函数对象,用户Number类型进行使用,不支持BigInt. Math 的所有属性与方法都是 ... 
- Redis中7种集合类型应用场景&redis常用命令
		Redis常用数据类型 Redis最为常用的数据类型主要有以下五种: String Hash List Set Sorted set 在具体描述这几种数据类型之前,我们先通过一张图了解下Redis内部 ... 
- redis 系列14 有序集合对象
		一. 有序集合概述 Redis 有序集合对象和集合对象一样也是string类型元素的集合,且不允许重复的成员.不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员 ... 
- redis中插入用户集合的语句,有四个属性
		一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 ... 
随机推荐
- luogu P3952 时间复杂度 模拟
			题目链接 luogu P3952 时间复杂度 题解 直接模拟即可 注意不要直接return 我真是naive ...... 代码 #include<map> #include<sta ... 
- django——模型层之多表操作
			django的多表操作 1.使用场景 在实际生产过程多,我们面对的数据纷繁复杂,此时就需要良好的数据结构设计,多表之间的约束关系为我们提供了数据管理以及查询的便利.在MYsql中我们利用外键(fore ... 
- List GroupBy真实用法,Reflection(反射)用法,Enum用法,正则,搜索下拉布局
			1.List GroupBy 用法 var _roomProducts = homesingProducts.GroupBy(t => t.RoomName); RoomedProducts ... 
- react_app 项目开发_遇到的坑
			1. favicon.ico <link rel="shortcut icon" type="image/x-icon" href="./fav ... 
- vue_源码 原理 剖析
			相关基础知识点 // 可以让 任意函数/方法 成功临时指定成对象的方法进行调用 - call/apply // 1. 根据伪数组生成 真数组 const lis = document.getEleme ... 
- IFuzzer:An Evolutionary Interpreter Fuzzer using Genetic Programming
			摘要:该论文主要提供了一种自动进化模糊测试技术来查找JavaScript解释器中的错误.模糊测试是一种自动化黑盒测试技术,用于通过提供随机数据作为输入来查找软件中的安全漏洞.然而,当目标是解释器时,模 ... 
- 动态规划 hdu 1024
			Max Sum Plus Plus Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ... 
- B-Tree与B+Tree简明扼要的区别
			原文:https://blog.csdn.net/zhuanzhe117/article/details/78039692 看了很多讲B树和B+树的文章,大多都是围绕各自的特性讲的,第一,树中每个结点 ... 
- mysql 字符集
			mysql -u root -p 输入密码进入mysql show variables like 'character%'; --显示字符集,像这样 \q退出mysql, 更改mysql配置文件 vi ... 
- gdb常用的指令
			推荐一篇详细的gdb文章:http://witmax.cn/gdb-usage.html 1. 常用的gdb 命令 编译程序时需要加上-g,之后才能用gdb进行调试:gcc -g main.c -o ... 
