Redis 常用指令

dump.rdb  lconfig  redis-benchmark  redis-check-aof  redis-check-rdb  redis-cli  redis-sentinel  redis-server
root@ubuntu-virtual-machine:/usr/local/bin# redis-server lconfig/redis.conf 
root@ubuntu-virtual-machine:/usr/local/bin# redis-cli -p 6379
127.0.0.1:6379> keys * # 查看所有的key
PONG
127.0.0.1:6379> 
root@ubuntu-virtual-machine:/usr/local/bin# EXISTS name 判断当前key是否存在
127.0.0.1:6379> move name 1 # 移除当前key,1代表当前数据库
127.0.0.1:6379> EXPIRE name 10 # 设置key的过期时间,单位是秒
(integer) 1
127.0.0.1:6379> ttl name # 查看当前key的剩余时间
(integer) -2
127.0.0.1:6379> ttl name # 查看当前key的剩余时间
(integer) -2
127.0.0.1:6379> type name # 查看 key 类型
string
127.0.0.1:6379> type age
string

查看Redis进程

Redis学习笔记_redis

127.0.0.1:6379> set key1 v1
OK
127.0.0.1:6379> keys *
1) "key1"
127.0.0.1:6379> EXISTS key1
(integer) 1
127.0.0.1:6379> APPEND key1 "hello" # 追加字符串,如果当前key不存在,就相当于setkey
(integer) 7
127.0.0.1:6379> get key1
"v1hello"
127.0.0.1:6379> STRLEN key1 # 获取字符长度
(integer) 7

#########################################################
127.0.0.1:6379> set views 0 # 设置数值
OK
127.0.0.1:6379> get views # 查看key
"0"
127.0.0.1:6379> incr views # 自增1
(integer) 1
127.0.0.1:6379> get views # 查看key
"1" 
127.0.0.1:6379> decr views # 自减1
(integer) 0
127.0.0.1:6379> INCRBY views 10 # 步长 增 10
(integer) 10
127.0.0.1:6379> DECRBY views 5 # 步长 减 10
(integer) 5


######################################################
# 字符串范围 range

127.0.0.1:6379> set key1 "hello,leett" # 设置 key1 值
OK
127.0.0.1:6379> get key1
"hello,leett"
127.0.0.1:6379> GETRANGE key1 0 3 # 截取字符串 [0,3]
"hell"
127.0.0.1:6379> GETRANGE key1 0 -1 # 获取全部的字符串和 get key 是一样的
"hello,leett"

# 替换
127.0.0.1:6379> set key2 abcdefg
OK
127.0.0.1:6379> get key2
"abcdefg"
127.0.0.1:6379> SETRANGE key2 1 xx #替换指定位置开始的字符串
(integer) 7

######################################################
# setex (set with expire) # 设置过期时间
# setnx (set if not exist) # 不存在再设置(在分布式锁中会常常使用!)

127.0.0.1:6379> setex key3 30  "hello" # 设置key3 得值为hello,30秒后过期
OK
127.0.0.1:6379> ttl key3
(integer) 24
127.0.0.1:6379> get key3
"hello"
127.0.0.1:6379> setnx mykey "redis" # 如果mykey 不存在,创建mykey
(integer) 1
127.0.0.1:6379> keys *
1) "mykey"
2) "key2"
3) "key1"
127.0.0.1:6379> ttl key3
(integer) -2
127.0.0.1:6379> setnx mykey "MongoDB" 如果mykey 存在,创建失败!
(integer) 0
127.0.0.1:6379> get mykey
"redis"


######################################################

127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3 # 同时设置多个值
OK
127.0.0.1:6379> KEYS *
1) "k3"
2) "k1"
3) "k2"
127.0.0.1:6379> mget k1 k2 k3 # 同时获取多个值
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> msetnx k1 v1 k4 v4 # msetnx 是一个原子性的操作,要么一起成功,要么一起失败!
(integer) 0
127.0.0.1:6379> get k4
(nil)

# 这里得key是一个巧妙的设计,user:{id}:{filed},如此设计在Redis中是完全ok了!
127.0.0.1:6379> mset user:1:name lite user:1:age 18
OK
127.0.0.1:6379> mget user:1:name user:1:age
1) "lite"
2) "18"


######################################################

getset # 先get 然后在 set
127.0.0.1:6379> getset db redis # 如果不存在值,则返回 nil
(nil)
127.0.0.1:6379> get db
"redis"
127.0.0.1:6379> getset db mysql # 如果存在值,则获取原来的值,并设新的值
"redis"
127.0.0.1:6379> get db
"mysql"