开发者

shell批量设置key过期时间的两种方法步骤

1、脚本如下,这个脚本的作用是找到Redis中某个数据库下的所有key,并批量设置统一的过期时间(这种工作最好交给开发来做)

(1)通过shell脚本批量设置db1中所有key的过期时间

#!/usr/bin/env bash
#查询db1下的所有key,并批量设置统一过期时间

#获取db1下的所有key,并通过while循环赋值给变量key,-n 1表示进入db1
/alidata/redis/bin/redis-cli -h 127.0.0.1 -p 6381  -n 1 keys  '*' |    
while read key
do    
    #进入db1并批量设置统一的过期时间为1296000秒
    /alidata/redis/bin/redis-cli -h 127.0.0.1php -p 6381 android -n 1 expire ${key} 1296000 
done

(2)登录redis-6381查看效果

[root@jxq-c2-16-2 shell]# sh redis_ttl.sh           #执行脚本
(integer) 1
(integer) 1
(integer) 1

#登录reids6381
[root@jxq-c2-16-2 shell]# /alidata/redis/bin/redis-cli -h 127.0.0.1 -p 6381   
127.0.0.1:6381> select 1                  #进入db1
OK
127.0.0.1:6381[1]> keys *
1) "name3"
2) "rocen4"
3) "wenqiang"
127.0.0.1:6381[1]> ttl name3             #db1下所有key的过期时间已经修改为15天
(integer) 1295970
127.0.0.1:6381[1]> ttl rocen4
(integer) 1295963
127.0.0.1:6381[1]> ttl wenqiang
(integer) 1295959

2、这个脚本的作用是找到redis中没有设置过过期时间的key,并批量设置统一的过期时间为1小时

#!/usr/bin/env bash
#查询db1中哪些key没有设置过期时间,并批量设置统一过期时间为15天(12php96000秒)

#查询db1中的所有key并通过while循环赋值给变量key
/alidata/redis/bin/redis-cli -h 127.0.0.1 -p 6381  -n 1 keys  '*' |
while read key
do
    #获取db1中每一个key的过期时间
    key_val=`/alidata/redis/bin/redis-cli -h 127.0.0.1 -p 6381  -n 1 ttl ${key}`
    #判断哪些key没有设置过期时间
    if [ "$key_val" -eq "-1" ]
    then
        #将dbandroid1中没有设置过期时间的key重新设置过期时间为3600s
        /alidata/redis/bin/redis-cli -h 127.0.0.1 -p 6381  -n 1 expire ${key} 3600
    fi
    
done

到此这篇关于shell批量设置key过期时间的方法步骤的文章就介绍到这了,更多相关shell批量设置key过期时间内容请搜索编程客栈(www.devze.com)以前的文章或继续浏js览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新运维

运维排行榜