主题

  为啥会有这篇文章呢? 在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 批量删除键的更多相关文章

  1. redis批量删除键的操作

    网上也有很多关于批量删除的命令,例如,我们要删除以KEY开头的键.linux系统中当屏幕显示127.0.0.1:6379时,采用如下命令 redis-cli -h 192.168.1.1 -p 637 ...

  2. Redis批量删除key的小技巧,你知道吗?

    在使用redis的过程中,经常会遇到要批量删除某种规则的key,但是redis提供了批量查询一类key的命令keys或scan,没有提供批量删除某种规则key的命令,怎么办?看完本文即可,哈哈. 本文 ...

  3. redis数据库如何批量删除键和设置过期时间?

    我们可以借助Linux中的xargs,在终端中执行命令来实现这两个功能. 一.批量删除键 批量删除以"key"开头key的方法,需要借助Linux中的xargs,在终端中执行以下命 ...

  4. Java Redis的Pipeline管道,批量操作,节省大量网络往返时间 & Redis批量读写(hmset&hgetall) 使用Pipeline

    一般情况下,大家使用redis去put/get都是先拿到一个jedis实例,然后操作,然后释放连接:这种模式是 请求-响应,请求-响应 这种模式,下一次请求必须得等第一次请求响应回来之后才可以,因为r ...

  5. redis 批量删除操作

    redis 批量删除操作 需要在redis里面清空一批数据,redis没有支持通配符删除, 只有del key1 key2 ... 但是可以通配符获取 KEYS PATTERN 然后利用linux管道 ...

  6. redis批量设置过期时间

    Redis 中有删除单个 Key 的指令 DEL,但好像没有批量删除 Key 的指令,不过我们可以借助 Linux 的 xargs 指令来完成这个动作.代码如下: redis-cli keys &qu ...

  7. Redis批量删除KEY的方法

    Redis 中有删除单个 Key 的指令 DEL,但好像没有批量删除 Key 的指令,不过我们可以借助 Linux 的 xargs 指令来完成这个动作. 代码如下: redis-cli keys “* ...

  8. 使用python向Redis批量导入数据

    1.使用pipeline进行批量导入数据.包含先使用rpush插入数据,然后使用expire改动过期时间 class Redis_Handler(Handler): def connect(self) ...

  9. redis批量灌库

    需求:将批量数据灌入redis中 如果通过代码形式将数据灌入redis中,效率比较低,以下将根据redis的特性进行快速的批量灌库 环境:centos7 将数据整理成规定格式的文件,比如: SET k ...

随机推荐

  1. Luogu 3690 Link Cut Tree

    Luogu 3690 Link Cut Tree \(LCT\) 模板题.可以参考讲解和这份码风(个人认为)良好的代码. 注意用 \(set\) 来维护实际图中两点是否有直接连边,否则无脑 \(Lin ...

  2. BZOJ4561 JLoi2016 圆的异或并 【扫描线】【set】*

    BZOJ4561 JLoi2016 圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区 ...

  3. Django 向数据表中添加字段方法

    在模型order中添加字段discount字段,并给予初始值0 方法: 先在models.py中修改模型 添加 discount = models.DecimalField(max_digits=8, ...

  4. Flask第六篇——项目配置文件

    我们在开发中,通常将一些需要用到的配置选项单独放在一个文件中,比如叫configs.py中.然后通过一些方式加载. 现在将加载配置文件的方法罗列如下: 1.先新建文件configs.py,文件代码: ...

  5. mock的使用二(根据数据模板生成模拟数据)

    Mock.mock( rurl?, rtype?, template|function( options ) ) 根据数据模板生成模拟数据. Mock.mock( template ) 根据数据模板生 ...

  6. 军哥 LNMP 常见问题

    安装memcached出错: Install memcached...Notice: memcached-1.4.25.tar.gz not found!!!download now...--2016 ...

  7. undefined vs. null

    undefined vs. null 一.相似性 在JavaScript中,将一个变量赋值为undefined或null,老实说,几乎没区别. var a = undefined; var a = n ...

  8. C#如何:启用和禁用自动绑定重定向 (微软)

    https://msdn.microsoft.com/zh-cn/library/2fc472t2.aspx 如何:启用和禁用自动绑定重定向 .NET Framework (current versi ...

  9. curl post数据

    调用方式: $header = self::getHeader(); $data = self::postUrl($url, $header); /** * 组合Header * @return ty ...

  10. 微服务架构 vs. SOA架构

    面向服务架构(SOA)已经存在有些年头了,这是一种用于设计软件的伟大原则.在SOA中,所有组件都是独立自主的,并能为其他组件提供服务.要替换掉系统中的某些部分而不对整个系统造成较大的影响本是个难题,然 ...