文章目录
0、参考资料
官方:
https://redis.io/commands
https://redis.io/topics/rediscli
菜鸟教程:
https://www.runoob.com/redis/redis-commands.html
1、常用管理命令
启动/连接/停止
redis-server [--port 6379] #如果命令参数比较多,那就使用配置文件来启动
redis-server [xx/xx/redis.conf]
redis-cli [-h 127.0.0.1 -p 6379]
redis-cli连接到实例后敲shutdown命令或者kill redis-pid #两种方式命令效果一样
发送命令
方法1:
redis-cli ping #连接redis实例后发出ping命令,可用于shell脚本
方法2:
127.0.0.1:6379> ping #交互模式,输入ping命令来测试连通性
PONG
哨兵模式登录到对应的redis实例
先登录Sentinel 找到对应实例信息,IP+端口
redis-cli -p 26379 info|grep myredis-test
master140:name=myredis-test,status=ok,address=1.1.3.51:6395,slaves=1,sentinels=3
# myredis-test 为 Redis-Master-Name
然后根据第一步获取的ip+端口信息登录到对应实例
redis-cli -h 1.1.3.51 -p 6395
1.1.3.51:6395>
集群模式登录到对应的redis实例
redis-cli -c -p 36379 #登录集群的redis要加-c参数
cluster info
cluster nodes
2、常用key操作命令
2.1、常规操作
获取key总个数
127.0.0.1:6379> dbsize
(integer) 6
获取key总数时不会遍历所有的key,直接获取内部变量,时间复杂度O(1)。
获取所有的key
127.0.0.1:6379> keys *
*表示通配符,表示任意字符,会遍历所有键显示所有的键列表,时间复杂度O(n),在生产环境会导致整个redis实例卡主,甚至穿透缓存把关系型数据库也搞崩溃。
查询key是否存在
127.0.0.1:6379> exists javastack java
(integer) 2
可以查询多个,返回存在的个数。
删除key
127.0.0.1:6379> del java javastack
(integer) 1
可以删除多个,返回删除成功的个数。
查询key类型
127.0.0.1:6379> type javastack
string
移动key
如把javastack移到2号数据库
127.0.0.1:6379> move javastack 2
(integer) 1
127.0.0.1:6379> select 2
OK
127.0.0.1:6379[2]> keys javastack
1) "javastack"
查询key的生命周期(秒)
127.0.0.1:6379[2]> ttl javastack
(integer) -1
-1:永远不过期。
设置key过期时间
127.0.0.1:6379[2]> expire javastack 60
(integer) 1
127.0.0.1:6379[2]> ttl javastack
(integer) 55
设置key永不过期
127.0.0.1:6379[2]> persist javastack
(integer) 1
更改key名称
127.0.0.1:6379[2]> rename javastack javastack123
OK
2.2、删除key 生产姿势
redisadmin方式 支持删除单key,模糊匹配
redisadmin -P 6381 -t delete -m "匹配"
redis-cli方式
给定单个
redis-cli -p 6381
127.0.0.1:6381> exists keyname //清除之前最好看存在不存在,
127.0.0.1:6381> del keyname
如果给的key很多,或者是key的列表文件,两种方法
方法一:
$ cat key.txt |xargs -L 2000 redis-cli -n 0 -p 6379 DEL #-L 分批删除
方法二:
for i in `cat key.txt` #给定的key文件
do
redis-cli -p xxx del $i && echo "del $i is ok" >> result.log
done
如果是key的前缀,模糊匹配
$redis-cli -n 0 -p xxx --scan --pattern "k*" | xargs -L 2000 redis-cli -n 0 -p xxx DEL
//参数说明如下
-n:具体的db
-p:端口
--scan : 扫描方式,不阻塞 redis-server
--pattern:匹配的前缀,给定k,--pattern为 k*
在集群中删除key
如果给定 key 的前缀,需要模糊匹配。注意每个主节点都要执行
> CLUSTER NODES # 随便登一节点,查看集群信息,找出集群的主节点
// 例如:清楚以test-c1开头的key
redis_list=("192.168.0.117:36379" "192.168.0.118:36379" "192.168.0.117:36383" "192.168.0.119:36379" "192.168.0.119:36383" "192.168.0.119:36381" "192.168.0.118:36383" "192.168.0.118:36381" "192.168.0.117:36381")
for info in ${redis_list[@]}
do
ip=`echo $info | cut -d \: -f 1`
port=`echo $info | cut -d \: -f 2`
(redis-cli -c -h $ip -n 0 -p $port --scan --pattern "test-c1*" | xargs -L 2000 -n1 redis-cli -c -h $ip -n 0 -p $port DEL >> /tmp/del_key.txt) && echo "$ip:$port is ok!" >> del_key.log
done
3、常用字符串操作命令
存放键值
127.0.0.1:6379> set javastack 666
OK
如果key不存在则建立,xx:如果key存在则修改其值,也可以直接使用setnx/setex命令。
获取键值
127.0.0.1:6379[2]> get javastack
"666"
值递增/递减
127.0.0.1:6379[2]> incr javastack
(integer) 667
如果字符串中的值是数字类型的,可以使用incr命令每次递增,不是数字类型则报错。
一次想递增N用incrby命令,如果是浮点型数据可以用incrbyfloat命令递增。
同样,递减使用decr、decrby命令。
批量存放键值
127.0.0.1:6379[2]> mset java1 1 java2 2 java3 3
OK
批量获取键值
127.0.0.1:6379[2]> mget java1 java2
1) "1"
2) "2"
获取值长度
127.0.0.1:6379[2]> strlen javastack
(integer) 3
追加内容
127.0.0.1:6379[2]> append javastack hi
(integer) 5
向键值尾部添加,如上命令执行后由666变成666hi
获取部分字符
127.0.0.1:6379[2]> getrange javastack 0 4
"javas"
4、常用集合操作命令
存储值
// 这里有8个值(2个java),只存了7个
127.0.0.1:6379> sadd langs java php c++ go ruby python kotlin java
(integer) 7
获取元素
127.0.0.1:6379> smembers langs #获取所有元素
127.0.0.1:6379> srandmember langs 3 #随机获取3个元素
判断集合是否存在元素
127.0.0.1:6379> sismember langs go
(integer) 1
获取集合元素个数
127.0.0.1:6379> scard langs
(integer) 7
删除集合元素
127.0.0.1:6379> srem langs ruby kotlin
(integer) 2
弹出元素
127.0.0.1:6379> spop langs 2
5、常用有序集合操作命令
存储值
127.0.0.1:6379> zadd footCounts 16011 tid 20082 huny 2893 nosy
(integer) 3
获取元素分数
127.0.0.1:6379> zscore footCounts tid
"16011"
//获取排名范围排名
// 获取所有,没有分数
127.0.0.1:6379> zrange footCounts 0 -1
1) "nosy"
2) "tid"
3) "huny"
// 获取所有及分数
127.0.0.1:6379> zrange footCounts 0 -1 Withscores
1) "nosy"
2) "2893"
3) "tid"
4) "16011"
5) "huny"
6) "20082"
//获取指定分数范围排名
127.0.0.1:6379> zrangebyscore footCounts 3000 30000 withscores limit 0 1
1) "tid"
2) "16011"
增加指定元素分数
127.0.0.1:6379> zincrby footCounts 2000 tid
"18011"
获取集合元素个数
127.0.0.1:6379> zcard footCounts
(integer) 3
获取指定范围分数个数
127.0.0.1:6379> zcount footCounts 2000 20000
(integer) 2
删除指定元素
127.0.0.1:6379> zrem footCounts huny
(integer) 1
获取元素排名
127.0.0.1:6379> zrank footCounts tid
(integer) 1
6、常用列表操作命令
存储值
//左端存值
127.0.0.1:6379> lpush list lily sandy
(integer) 2
//右端存值
127.0.0.1:6379> rpush list tom kitty
(integer) 4
//索引存值
127.0.0.1:6379> lset list 3 uto
OK
弹出元素
//左端弹出
127.0.0.1:6379> lpop list
"sandy"
//右端弹出
127.0.0.1:6379> rpop list
"kitty"
获取元素个数
127.0.0.1:6379> llen list
(integer) 2
获取列表元素
//获取前4个
127.0.0.1:6379> lrange users 0 3
// 获取所有
127.0.0.1:6379> lrange users 0 -1
// 从右端索引,从右往左数3个
127.0.0.1:6379> lrange users -3 -1
//从左开始,第三个元素
127.0.0.1:6379> lindex list 2
// 从右端获取,从右往左数第5个元素
127.0.0.1:6379> lindex list -5
删除元素
1、根据值删除
// count=0 删除所有
127.0.0.1:6379> lrem userids 0 111
(integer) 2
// count > 0 从左端删除前count个
127.0.0.1:6379> lrem userids 3 222
(integer) 3
// count < 0 从右端删除前count个
127.0.0.1:6379> lrem userids -3 222
(integer) 2
2、范围删除
// 只保留2-4之间的元素
127.0.0.1:6379> ltrim list 2 4
OK
7、常用散列操作命令
存放键值
//操作单个
127.0.0.1:6379> hset user name javastack
(integer) 1
//操作多个
127.0.0.1:6379> hmset user name javastack age 20 address china
OK
//不存在时
127.0.0.1:6379> hsetnx user tall 180
(integer) 0
获取字段值
//单个
127.0.0.1:6379> hget user age
"20"
//多个
127.0.0.1:6379> hmget user name age address
//获取所有键与值
127.0.0.1:6379> hgetall user
//获取所有字段
127.0.0.1:6379> hkeys user
//获取所有值
127.0.0.1:6379> hvals user
判断字段是否存在
127.0.0.1:6379> hexists user address
(integer) 1
获取字段数量
127.0.0.1:6379> hlen user
(integer) 4
递增/减
127.0.0.1:6379> hincrby user tall -10
(integer) 170
删除字段
127.0.0.1:6379> hdel user age
(integer) 1