linux中批量删除redis指定前缀的key

263 阅读2分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。 在redis开发当中,有一些永不过期的key,这些key有些是热词,是有必要存在的,也有一些key是忘记了设置失效时间引起的,长期堆积这些不过期的key值,会占用内存空间,造成不必要的浪费,那如何回收这部分资源呢? 对于指点前缀的key,可以使用xargs语法清除,但是使用批量删除之前,先要指定匹配规则,之前在网上看到有人提出使用 keys关键字来匹配的方法,具体语法如下: redis -cli -h ‘127.0.0.1’ -p ‘6379’ -a password KEYS “key*” | xargs redis-cli -h ‘127.0.0.1’ -p ‘6379’ -a password del

使用该语法可以批量删除匹配到指定前缀的key,但是有一个限制,就是使用这个语法删除的keys数量不能太大,如果数据量较大的话,很容易引起redis阻塞,要想避免引起此类问题,则可以使用另一个关键字 scan 来解决,具体语法如下: redis-cli -h ‘127.0.0.1’ -p ‘6379’ -a password --scan --pattern “key*” | xargs -L 100 redis-cli -h ‘127.0.0.1’ -p ‘6379’ -a password del

该语句可以循环删除匹配到的关键字,不会引起redis阻塞的问题,其中 -L 100表示批量删除100行,如果不需要这个条件的话,直接去掉就可以。

Redis常⽤命令(服务器相关)

命令:ping,测试连接是否连通。

命令:echo message,输出messgae

命令:quit/exit,退出连接

命令:select index,选中数据库,默认情况下,redis有16个数据库,0~15,默认连接数据库0。

命令:dbsize,返回当前数据库中key的数⽬。

命令:info [section], 获取服务器的信息,加上参数section,则返回部分信息;不加参数,返回所有信息。

命令:BGSAVE,在后台执行初始化操作,并以异步的方式将当前数据库的数据保存在磁盘中。

命令:ROLE 查看主从实例所属的角色,角色包括三种,分别是master、slave、sentinel