redis 批量删除键
主题
为啥会有这篇文章呢? 在redis里我需要批量删除一些 "特殊" 的数据...这些特殊的数据用正常方法比较难删除...所以记录一下我的删除方法..
背景与问题
我再用SpringBoot集成Spring的@Cacheable的时候遇到了一些比较麻烦的事情...
第一个是序列化问题...相信大家一般都会遇到过..

redisTemplate默认用的是JdkSerializationRedisSerializer

所以会生成这个样子的字符串...
其实这个样子的字符串也没关系......只要他能正常删除就行了...可是偏偏很多可视化工具都不支持...

redis本身是没有批量删除命令的...可是话工具是提供批量删除的..原理是把所有满足条件的key找出来1个1个删除...那现在问题就是他key不认识...是乱码..所以也就删除不了了..
在命令行1个1个删除是没问题的...但是key多了就GG了.......
解决办法
办法1
用这种jdk自带的序列化来序列化string的key我觉得是不合理的...这个key看都看不懂...所以我们可以指定用其他方法来序列化key...
spring本身提供了String的序列化方式(StringRedisSerializer)...所以我们可以用这个序列化类来序列化key

这样生成的key很正常..很美观...也是我们想要的

方法2
方法1是一种解决办法...但是最为学习来说我希望能有一种不是回避而是通过技术手段来解决这个问题的方法...方法1的解法是可行的.也是不错的...但到底是有没有办法批量去删除redis的key...
有的...网上大部分给的解法是这样的:
redis-cli -h 192.168.0.8 -p 6380 keys "obj_base_*" |xargs redis-cli -h 192.168.0.8 -p 6380 del
这样是一种解决办法...但是可能是我LINUX命令不太好吧...这种删除方法对于key里面有\xAC等jdk序列化生成的字符的时候是会报错的...如果这种方法不报错...那可视化工具也是能删除的...所以这就很尴尬了...
xargs: WARNING: a NUL character occurred in the input. It cannot be passed through in the argument list. Did you mean to use the --null option?
可能精通linux命令的小朋友会有什么命令可以处理这些字符吧...但是我还不太会....= =
所以我自己用另外1种办法...
我想:在命令行可以删除.那再命令行可以获取真正的带引号的字符串..那只要批量执行这个命令行就OK了吧..
redis是支持lua脚本的...那我自己写个lua脚本就行了吧
花了十几分钟学习了语法以后成功写出了1个非常简单的脚本...但是还是蛮实用的..
local key=KEYS[]
local result={};
local list=redis.call("keys", key);
for i,v in ipairs(list) do
redis.call("del", v);
table.insert(result,i,v);
end return result;

这样就比较完美的解决了批量删除问题.
小结
redis可以支持lua脚本真的很好...通过这个脚本可以做一些扩展功能...
那么我能不能自定义一些dels命令去调用lua脚本做批量删除呢? 值得尝试.....
redis 批量删除键的更多相关文章
- redis批量删除键的操作
		网上也有很多关于批量删除的命令,例如,我们要删除以KEY开头的键.linux系统中当屏幕显示127.0.0.1:6379时,采用如下命令 redis-cli -h 192.168.1.1 -p 637 ... 
- Redis批量删除key的小技巧,你知道吗?
		在使用redis的过程中,经常会遇到要批量删除某种规则的key,但是redis提供了批量查询一类key的命令keys或scan,没有提供批量删除某种规则key的命令,怎么办?看完本文即可,哈哈. 本文 ... 
- redis数据库如何批量删除键和设置过期时间?
		我们可以借助Linux中的xargs,在终端中执行命令来实现这两个功能. 一.批量删除键 批量删除以"key"开头key的方法,需要借助Linux中的xargs,在终端中执行以下命 ... 
- Java Redis的Pipeline管道,批量操作,节省大量网络往返时间  &  Redis批量读写(hmset&hgetall) 使用Pipeline
		一般情况下,大家使用redis去put/get都是先拿到一个jedis实例,然后操作,然后释放连接:这种模式是 请求-响应,请求-响应 这种模式,下一次请求必须得等第一次请求响应回来之后才可以,因为r ... 
- redis 批量删除操作
		redis 批量删除操作 需要在redis里面清空一批数据,redis没有支持通配符删除, 只有del key1 key2 ... 但是可以通配符获取 KEYS PATTERN 然后利用linux管道 ... 
- redis批量设置过期时间
		Redis 中有删除单个 Key 的指令 DEL,但好像没有批量删除 Key 的指令,不过我们可以借助 Linux 的 xargs 指令来完成这个动作.代码如下: redis-cli keys &qu ... 
- Redis批量删除KEY的方法
		Redis 中有删除单个 Key 的指令 DEL,但好像没有批量删除 Key 的指令,不过我们可以借助 Linux 的 xargs 指令来完成这个动作. 代码如下: redis-cli keys “* ... 
- 使用python向Redis批量导入数据
		1.使用pipeline进行批量导入数据.包含先使用rpush插入数据,然后使用expire改动过期时间 class Redis_Handler(Handler): def connect(self) ... 
- redis批量灌库
		需求:将批量数据灌入redis中 如果通过代码形式将数据灌入redis中,效率比较低,以下将根据redis的特性进行快速的批量灌库 环境:centos7 将数据整理成规定格式的文件,比如: SET k ... 
随机推荐
- 接口测试框架——第三篇:发送(requests)
			把下面的代码放在requests_module.py文件中 # coding: utf-8 import requests import logging from requests.exception ... 
- 随机生成国内ip
			function rand_ip(){ $ip_long = array( array('607649792', '608174079'), //36.56.0.0-36.63.255.255 arr ... 
- gprof的使用介绍
			转于:http://blog.chinaunix.net/uid-25194149-id-3215487.html #不知道这是在哪里找的了,感谢各位~ 性能分析工具gprof介绍Ver:1.0 目录 ... 
- toxiproxy 安装试用
			备注: 实际上是一个代理工具,但是又不是简单的进行代理(tcp,可以配置策略,toxics 实现延迟,模拟故障, 对于这个大家可能了解的就是netflix 公司的chaos monkey, ... 
- js 正则表达式符号含义
			\ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界. -或- 对正则表达式功 ... 
- Proteus 仿真运算放大器出现 GMIN 问题
			Proteus 仿真运算放大器出现 GMIN 问题 为了仿真一个反相运算放大器,在仿真时出现 GMIN 问题,将 后面的 4.7UF 去掉就可以正常仿真. 初步检查是因为输入频率太低,输入时我用的是 ... 
- Jenkins的pipeline
			说明 再官网文档上有说明pipeline的工作流程,具体可以参考pipeline文档和语法文档. 这里将pipeline的生命周期图贴出来 我们暂时不会用到完整的流程,只摘取有用的部分,完成最小的流 ... 
- 学生选课数据库SQL语句练习题
			一. 设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ... 
- docker监控的一点想法
			目前项目内部署了docker,于是涉及到关于监控的事情,参考一些经典实例以及一些自己的想法,总结一下思路. 1.关于监控的内容 监控宿主机本身 监控宿主机本身还是比较简单的,同其他服务器监控类似,对c ... 
- kafka 常用命令
			Kafka 解压,进入kafka目录下的bin目录 启动zk nohup ./zookeeper-server-start.sh ../config/zookeeper.properties & ... 
