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 ...
随机推荐
- Codeforces 954H Path Counting 【DP计数】*
Codeforces 954H Path Counting LINK 题目大意:给你一棵n层的树,第i层的每个节点有a[i]个儿子节点,然后问你树上的简单路径中长度在1~n*2-2之间的每个有多少条 ...
- 常用的SQL语句大全
一.基础 1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备 ...
- jQuery关于复制(复制隐藏文字+显示文字)跳转,Clipboard
html: (直接上扎实的数据,框子自己搭建) <script type="text/javascript" src="../../js/jquery.min.js ...
- hoverfly api 模拟框架了解
What is Hoverfly? Hoverfly is a lightweight, open source API simulation tool. Using Hoverfly, you ca ...
- parcel vue 简单使用
1.安装依赖 yarn global add parcel-bundler yarn add babel-preset-env --dev yarn add parcel-plugin-vue --d ...
- nginx 启用http2 https 无法访问的问题
原因: 1. openssl 版本过低 解决方法:进行升级 yum update openssl 2.ssl_ciphers 配置有问题 解决方法:修改为 ssl_ci ...
- 关于浏览器和IIS基础的简单理解
浏览器 输入域名或者IP地址,按回车访问后:发生了什么??IIS是如何工作的?为什么能这么工作?? 1 浏览器和IIS 分别是两个应用程序:浏览器访问网址实际就是 两个应用程序的数据交互往来: ...
- 使用Apache Archiva管理Maven仓库
1 . 私服简介 私服是架设在局域网的一种特殊的远程仓库,目的是代理远程仓库及部署第三方构件.有了私服之后,当 Maven 需要下载构件时,直接请求私服,私服上存在则下载到本地仓库:否则,私服请求外部 ...
- display的flex属性使用详解
flex的兼容性在pc端还算阔以,但是在移动端,那就呵呵了.今天我们只是学习学习,忽略一些不重要的东西. 首先flex的使用需要有一个父容器,父容器中有几个items. 父容器:container 属 ...
- Linux文件属性,类型,ls -lhi解释行列
Linux文件属性(描述信息) -i inode节点号 -h 人类可读 ls -lhi 1703938 drwxr-xr-x 2 rsync rsync 4.0K Jun 7 07:24 gamese ...