Redis 通过 scan 找出不过期的 key
Redis 通过 Key 找出 scan 不过
2023-09-27 14:26:01 时间
SCAN 命令是一个基于游标的迭代器(cursor based iterator):SCAN 命令每次被调用之后,都会向用户返回一个新的游标,用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数,以此来延续之前的迭代过程。
注意:当 SCAN 命令的游标参数被设置为 0 时,服务器将开始一次新的迭代,而当服务器向用户返回值为 0 的游标时,表示迭代已结束!
编写脚本
#!/bin/bash
db_ip=127.0.0.1 # redis ip
db_port=6379 # redis 端口
password=ibalife # redis 密码
cursor=0 # 第一次游标
cnt=100 # 每次迭代的数量
new_cursor=0 # 下一次游标
redis-cli -h $db_ip -p $db_port -a $password scan $cursor count $cnt > scan_tmp_result
new_cursor=`sed -n '1p' scan_tmp_result` # 获取下一次游标
sed -n '2,$p' scan_tmp_result > scan_result # 获取 keys
cat scan_result |while read line # 循环遍历所有 keys
do
ttl_result=`redis-cli -h $db_ip -p $db_port -a $password ttl $line` # 获取 key 过期时间
if [[ $ttl_result == -1 ]];then # 判断过期时间,-1 是不过期
echo $line >> no_ttl.log # 追加到指定文件
fi
done
while [ $cursor -ne $new_cursor ] # 若 游标 不为 0 ,则证明没有迭代完所有的 key,继续执行
do
redis-cli -h $db_ip -p $db_port -a $password scan $new_cursor count $cnt > scan_tmp_result
new_cursor=`sed -n '1p' scan_tmp_result`
sed -n '2,$p' scan_tmp_result > scan_result
cat scan_result |while read line
do
ttl_result=`redis-cli -h $db_ip -p $db_port -a $password ttl $line`
if [[ $ttl_result == -1 ]];then
echo $line >> no_ttl.log
fi
done
done
rm -rf scan_tmp_result
rm -rf scan_result
注意,若你的 redis 占用内存很大,可以使用 tmux 命令新开一个窗口。最后所有符合的要求的 key 都会保存在 no_ttl.log 文件中
相关文章
- 【转】NoSQL初探之人人都爱Redis:(1)Redis简介与简单安装
- PHP 操作redis 详细讲解转的
- 通过多线程处理提高Redis性能
- 秒杀场景:如何通过 Redis 减库存?
- CentOS7 通过移植二进制文件的方式安装redis、nginx以及dotnet core的简单办法
- Redis过期策略
- redis事务
- 透彻理解redis
- Redis:解决分布式高并发修改同一个Key的问题
- redis内存淘汰策略
- 通过原理理解为什么Redis的pipeline可以有效提升性能
- node-23-redis
- docker 实现redis集群搭建(二)
- spring 整合 redis 单机版
- 通过REDIS实现限制API调用次数