Redis常见应用场景
Redis特点
- 内存数据库,高速读写
- 支持数据的持久化RDB和AOF
ROB:RDB 是 Redis 默认的持久化方案。在指定的时间间隔内,执行指定次数的写操作,则会将内存中的数据写入到磁盘中。即在指定目录下生成一个dump.rdb文件。Redis 重启会通过加载dump.rdb文件恢复数据。
AOF:Redis 默认不开启。它的出现是为了弥补RDB的不足(数据的不一致性),所以它采用日志的形式来记录每个写操作,并追加到文件中。Redis 重启的会根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作。 - 丰富多样的数据类型:string、hash、set、sorted set、bitmap、hyperloglog
- Redis的所有操作都是原子性的,还支持对几个操作合并后的原子性操作,支持事务
数据类型及应用场景
字符串
最基本的数据类型,首先key是字符串类型,其他的数据都是在字符串的基础上构建的。
set命令
set key value [ex seconds] [px millseconds] [nx|xx]
- ex seconds:键过期时间
- px milliseconds:为键设置毫秒级过期时间
- nx:键必须不存在时才可以设置成功,用于添加
- xx:键必须存在是才设置成功,用于更新
mset,mget命令
批量设置和获取命令,在操作多个key时可以节省网络传输时间
mset key value [key value...]
mget key [key...]
其他字符串命令
incr对值进行加1操作,如果不是整数,返回错误,如果不存在按照从0开始
decr对值进行减1操作,其他与incr相同
incrby,decrby,增加减去指定的数
应用场景
- 缓存:将数据已字符串的方式存储
- 计数器功能:比如视频播放次数、点赞次数。
- 共享session:数据共享功能,Redis作为独立的应用软件用来存储一些共享数据供多个实例访问。
字符串有很多的命令可以使用,可以根据使用场景的不同灵活加以使用
hash
hash一般也被称作字典,Redis自己也可以作为一个比较大的hash存储。
hset key filed value
hsetnx key filed value //与setnx命令一样,不存在时设置值,用于添加,作用在filed
hget key filed //获取值
hdel key filed //删除值
hlen key //计算filed的个数
hmset key filed value [filed value]//批量设置filed-value
hexists key filed //判断field是否存在
hkeys key //获取所有的filed
hvals key //获取所有的value
hgetall key //获取所有的filed-value,如果元素较多会存在阻塞Redis的可能
从上面列举的命令可以看出,hash的命令和字符串的很像,基本对字符串操作的命令,hash操作一般也存在,不过在前面加了h。
一些关系型数据库中不是很复杂的表,也无需复杂的关系查询,可以使用Redis中的hash来存储,也可以使用hash做表数据缓存。
列表
列表用来存储多个有序的字符串,一个列表最多可以存储2^32-1个元素,在Redis中可以对列表的两端插入push和弹出pop,还可以获取指定范围的元素。
rpush key value [value...] //从右端插入数据
lpush key value [value...] //从左端插入数据
lrange key start end //获取指定范围的元素列表
lindex key index //获取列表指定索引下标的元素
llen key //获取列表的长度
lpop key //从列表左侧弹出key
rpop key //从列表右侧弹出key
lrem key count value //从列表中找到等于value的元素,并进行删除,根据count的不同有不同的结果
lset key index newValue //修改指定索引下标的元素
blpop key timeout //阻塞式左弹出key
brpop key timeout //阻塞式右弹出key
应用场景
- 消息队列:可以使用Redis做消息队列,lpush+brpop或rpop命令,实现先进先出,如果消费失败客户端将key再放回去,消费成功才remove掉
常见使用搭配: - lpush+lpop 左进左出 栈
- lpush+rpop 左进右出 队列
- lpush+ltrim 有限集合
- lpush + brpop 消息队列
集合
集合可以用来保存多个字符串的元素,内部不允许有重复元素,集合内的元素是无序的,Redis支持集合的增删改查,同时支持多个集合取交集,并集,差集
sadd key value [value...] //添加元素
srem key value [value...] //删除元素
scard key //计算元素的个数
sismember key value //判断元素是否在集合中
srandmember key [count] //随机从集合中返回指定个数的元素,不写默认为1
spop key //从集合中随机取出元素
smembers key //获取集合中的所有元素
sinter key1 key2 //求集合的交集
sunion key1 key2 //求集合的并集
sdiff key1 key2 //求集合的差集
适用场景
- 标签
有序集合
保留了元素不能重合的特性,但是元素是有序的。
zadd key score member //score是可以重复的,添加key的时候指定分数
zcard key //计算成员个数
zscore key member //计算某个成员的分数
zrank key member //计算成员排名,从低到高
zrevrank key member //计算成员排名,从高到低
zrem key member [member...] //删除成员
zincrby key increment member //增加从成员的分数
zrange key start end [withscores] //从低到高返回指定排名的分数
zrevrange key start end [withscores] //从高到低返回指定排名的分数
zrangebyscore key min max [withscores] [limit offset count] //按照分数从低到高返回成员
zrevrange score key min max [withscores] [limit offset count] //按照分数从高到低返回成员
应用场景
- 排行榜:返回前面排名的元素之后再使用mget命令获取key信息。
原文出处:https://www.imooc.com/article/70762