清理redis集群所有数据库 flushall-cluster脚本

清理redis集群所有数据库 flushall-cluster脚本,第1张

在实际使用环境中,有时候我们需要清空所有redis集群的数据进行测试,这是使用这个脚本就开始发挥作用了。希望能帮到所需要的人。

cat /tmp/flushall-cluster.sh

脚本怎么使用

sh flushall-cluster.sh 主机地址 端口

参考:

flushall-cluster.sh

1 使用cli

FLUSHDB 清除一个数据库,FLUSHALL清除整个redis数据。

2 使用shell

redis-cli keys "*" | while read LINE do TTL=`redis-cli ttl $LINE`if [ $TTL -eq -1 ]then echo "Del $LINE"RES=`redis-cli del $LINE`fidone

删除 3600秒之后过期的

redis-cli keys "*" | while read LINE do TTL=`redis-cli ttl $LINE`if [ $TTL -ge 3600 ]then echo "Del $LINE"RES=`redis-cli del $LINE`fidone

删除某些前缀的

redis-cli KEYS "126.com*" | xargs redis-cli DEL

3 使用lua脚本

删除所有keyEVAL "return redis.call('del', unpack(redis.call('keys', ARGV[1])))" 0 *

删除某些key

EVAL "return redis.call('del', unpack(redis.call('keys', ARGV[1])))" 0 126.com*

redis对象 *** 作setTimeout()的用法如下:

setTimeout, expire

设定一个key的活动时间(s)

$redis->setTimeout('x', 3)

有关redis的一系列set *** 作总结如下:

//SET 集合的相关 *** 作

// sadd 集合添加数据 初始化数据

for($i=0$i <10 $i++){

$redis->sadd("myset",$i+rand(10,99))

}

//srem 删除集合中的一个元素

$bool = $redis->srem("myset",16)

echo (int) $bool

//sMove 将value元素从名称为srckey的集合移到名称为dstkey的集合

$bool = $redis->sMove("myset", "myset1", 35)

echo $bool

//smembers 显示集合中的元素

$data = $redis->smembers("myset")

// sIsMember, sContains 名称为key的集合中查找是否有value元素,有ture 没有 false

$bool = $redis->sismember("myset",555)

echo (int)$bool

//scard ssize集合key元素的个数

echo $redis->scard("myset")

//sInterStore

//求交集并将交集保存到output的集合

//$redis->sInterStore('output', 'key1', 'key2', 'key3')

$redis->sinterstore("output","myset","myset1")

$data = $redis->smembers("output")

echo "<pre>"

print_r($data)

// sUnionStore求并集并将并集保存到output的集合

//$redis->sUnionStore('output', 'key1', 'key2', 'key3')

$redis->sunionstore("uoutput","myset","myset1")

$data = $redis->smembers("uoutput")

echo "<pre>"

print_r($data)

//sort

// 排序,分页等

// 参数

// 'by' =>'some_pattern_*',

// 'limit' =>array(0, 1),

// 'get' =>'some_other_pattern_*' or an array of patterns,

// 'sort' =>'asc' or 'desc',

// 'alpha' =>TRUE,

// 'store' =>'external-key'

$data = $redis->sort("myset",array("sort"=>"desc"))

echo "<pre>"

print_r($data)

//ZSET 有序集合的相关 *** 作

//zadd添加元素 zAdd(key, score, member):

for($i=0$i <10 $i++){

$redis->zadd("zset",$i+rand(10,99),$i+rand(100,999))

}

//zrange zRange(key, start, end,withscores) 返回指定范围的元素

//zRevRange(key, start, end,withscores):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素.withscores: 是否输出socre的值,默认false,不输出

//zRangeByScore, zRevRangeByScore

//$redis->zRangeByScore(key, star, end, array(withscores, limit ))

//返回名称为key的zset中score >= star且score <= end的所有元素

$data = $redis->zrange("zset",0,3,"withscores") //end -1 返回所有元素 加withscores withscores做值 使用

echo "<pre>"

print_r($data)

//zDelete, zRem

//zRem(key, member) :删除名称为key的zset中的元素member

$redis->zrem("zset",456)

//zCount

//$redis->zCount(key, star, end)

//返回名称为key的zset中score >= star且score <= end的所有元素的个数

echo $redis->zcount("zset",10,50)

//zRemRangeByScore, zDeleteRangeByScore

$redis->zRemRangeByScore('key', star, end) //zremrangebyscore 删除 socre 大于star score 小于 end d的元素

//删除名称为key的zset中score >= star且score <= end的所有元素,返回删除个数

//zScore 返回名称为key的zset中元素val2的score

echo $redis->zScore("zset", 503)

//zRank, zRevRank zrank("set",value) 返回value 在集合中的位置 索引从0开始

echo $redis->zrank("zset",723)

//zIncrBy

//$redis->zIncrBy('key', increment, 'member')

//如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment

//zUnion/zInter 就集合的合集和交集

//HASH 哈希的相关 *** 作

//hset 初始化数据

for( $i=0$i <10 $i++){

$redis->hset("myhash",$i,rand(10,99)+$i)

}

//hget("myhash","key1") 返回哈希 myhash 中键为key1的对应的数值

echo $redis->hget("myhash","0")

//hLen 返回名称为h的hash中元素个数

echo $redis->hlen('myhash')

//hDel 删除名称为h的hash中键为key1的域

echo $redis->hdel("myhash","0")

// hKeys 返回名称为key的hash中所有键

$data = $redis->hkeys('myhash')

//hVals 返回名称为h的hash中所有键对应的value

$data = $redis->hvals("myhash")

//hGetAll 返回名称为h的hash中所有的键(field)及其对应的value

$data = $redis->hgetall("myhash")

echo "<pre>"

print_r($data)

//hExists 判断某个hash的对应的键是否存在

echo $redis->hexists("myhash","0")

//hMset 向名称为key的hash中批量添加元素

$redis->hmset("user:1",array("name1"=>"name1","name2"=>"Joe2"))

//hMGet 返回名称为h的hash中field1,field2对应的value

$data = $redis->hmget('user:1', array('name', 'salary'))

echo "<pre>"

print_r($data)

//Redis 相关 *** 作

//flushDB 清空当前数据库

//flushAll 清空所有数据库

//select 选择数据库

//$redis->select(0)

//move 把key1 移动到数据库2

$redis->move("key1",2)

//rename, renameKey 给key从新命名

//renameNx 与remane类似,但是,如果重新命名的名字已经存在,不会替换成功

//setTimeout, expire 设置key的生命时间

$redis->settimeout("user:1",10)

//expireat 指定一个key的生命时间为一个时间戳

//expireAt key存活到一个unix时间戳时间

$redis->expireat("myhash",time()+ 10)

//dbSize 查看现在数据库有多少key

$count = $redis->dbSize()

//auth 密码认证

$redis->auth('foobared')

//bgrewriteaof 使用aof来进行数据库持久化

$redis->bgrewriteaof()

//slaveof 通过执行 SLAVEOF host port 命令,可以将当前服务器转变为指定服务器的从属服务器(slave server)。

$redis->slaveof('10.0.1.7', 6379)

//save 将数据同步保存到磁盘

//bgsave 将数据异步保存到磁盘

//lastSave 返回上次成功将数据保存到磁盘的Unix时戳

//info 返回redis的版本信息等详情

echo "<pre>"

print_r($redis->info())

// type 返回key的类型值 1-5

//string: Redis::REDIS_STRING 1

//set: Redis::REDIS_SET 2

//list: Redis::REDIS_LIST 3

//zset: Redis::REDIS_ZSET 4

//hash: Redis::REDIS_HASH 5

//other: Redis::REDIS_NOT_FOUND 6

echo $redis->type("myset")//2


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/10028055.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-04
下一篇2023-05-04

发表评论

登录后才能评论

评论列表(0条)

    保存