1. Redis简介
redis全称 Remote Dictionary Service(远程字典服务)。Redis存储的都是K-V对,Redis里存放的任何一条数据都有唯一的key作为名称。Redis中,所有的key都存储在一个很大的字典中。一个Redis实例有多个库(database),可用过配置文件里的“databases”配置,库索引从0到databases-1,可以使用指令SELECT <index>
切换到不通的库。
注意:在Redis命令行,Redis的指令不区分大小写,但是key区分大小写。
2. Redis基础数据结构
Redis有五种基础的数据结构:string、list、hash、set、zset。其中list、hash、set、zset称为容器型数据结构,容器型数据结构有两条通用规则:
- 如果容器不存在,就创建一个,再进行操作。
- 如果容器里没有数据了,就立即删除,回收内存。
2.1 string(字符串)
string是Redis最简单的数据结构,一个key对应一个value。Redis的string实际上是使用数组实现的。
string基本指令有:
- SET:设置一个kv对,示例:
SET name lily
- GET:获取一个key对应的的value,示例:
GET name
- MSET:设置一个或多个kv对,示例:
MSET name lily age 18
- MGET:获取一个或多个key对应的value,示例:
MGET name age
- SETNX:设置一个kv对,如果该key不存在,设置成功;如果改成存在,设置失败,示例:
SETNX name lilei
- INCR:如果 value 是整数,还可以进行原子加一操作,示例:
INCR age
- DECR:如果 value 是整数,还可以进行原子减一操作,示例:
DECR age
2.2 list(列表)
Redis的list是链表实现的,所以其插入删除操作非常快,时间复杂度都是O(1),但是索引定位很慢,时间复杂度是O(n)。当list中没有元素了,该数据结构会自动删除,内存被回收。
list的基本指令有:
- LPUSH:从左边插入元素,可以插入多个。示例:
LPUSH students lily lilei zhangsan
- LPOP:从左边删除元素,默认删除一个元素。可以指定需要删除的个数,示例:
LPOP students 5
- RPUSH:从右边插入元素,用法同
LPUSH
- RPOP:从右边删除元素,用法同
LPOP
- LRANGE:列出指定范围里的元素(不会删除元素),示例:
LRANGE students 0 -1
- LINDEX:(时间复杂度O(n))获取指定位置的元素,示例:
LINDEX students 1
- LTRIM:(时间复杂度O(n))删除指定范围的元素,示例:
LTRIM students 1 2
list常用场景:
-
队列/消息队列
从list的一边push数据,从另一边pop数据,就可以作为队列或者消息队列使用。如果list里面没有数据,
LPOP
和RPOP
不会阻塞,都会立即返回空。如果用作消息队列,消费者需要处理LPOP
或RPOP
立即返回空的情况,一般的做法是如果返回为空,等待一段时间,再次获取
,但是等待时间不好确定,等待时间太短会拉高CPU,造成浪费;等待时间太长会降低QPS,影响性能。Redis为list设计了阻塞读指令:BLPOP
、BRPOP
,指令用法是BLPOP key1 [key2 ...] timeout
,这里BLPOP/BRPOP
里的B
是blocking
的意思。阻塞读在list没有数据的时候,会立即休眠,一旦有数据到了,则立刻醒过来。 -
栈
在list的同一边push和pop数据,就可以作为栈使用
-
消息队列
LPOP
或者RPOP
操作不会阻塞,如果list里面没有数据,LPOP
和RPOP
都会立即返回空,如果
2.3 hash(字典)
Redis的hash的值只能是字符串。
hash的基本指令:
- HMSET:写入数据,支持批量。示例:
HMSET 001 name lily age 18
,其中 001 是该条hash的key,name、age 是hash里面的field。 - HMGET:获取指定hash的某个field的value。示例:
HMGET 001 name
- HGETALL:获取指定hash的所有数据。示例:
HGETALL 001
- HINCRBY :如果hash内部的value是整型,可以使用
HINCRBY
进行原子加减操作(只需讲操作数设置为负数就是减法操作),示例:HINCRBY 001 age 1
,HINCRBY 001 age -1
2.4 set(集合)
Redis的set是无序的。
set的基本指令:
- SADD:加入集合。示例:
SADD students lily lilei
- SMEMBERS:列出集合内成员。示例:
SMEMBERS students
- SISMEMBER:查询某个成员是否存在。示例:
SISMEMBER students lily
- SREM:删除某个成员。示例:
SREM students lily
- SCARD:获取集合长度。示例:
SCARD students
- SPOP:弹出成员,可以指定需要弹出的个数(不知道默认是1)。示例:
SPOP students 5
2.5 zset(有序集合)
Redis的zset是一个很有特色的数据结构,一方面它是一个set,保证了内部value的唯一性,另一方面它可以给每个value赋予一个score,代表这个value的排序权重。它的内部实现采用的是”跳跃列表(skiplist)“。
zset基本指令:
- ZADD:增加成员。示例:
ZADD students 95 lily 85 lilei 70 zhangsan 55 lisi
- ZRANGE:正序获取指定个数的成员。示例:
ZRANGE students 0 -1
- ZREVRANGE:倒序获取指定个数的成员。示例:
ZREVRANGE statuents 0 -1
- ZRANGEBYSCORE:根据score范围获取成员,正序排列。示例:
ZRANGEBYSCORE students 0 60
- ZREVRANGEBYSCORE:根据score范围获取成员,倒叙排列。示例:
ZREVRANGEBYSCORE students 100 0
- ZREM