Redis
简介
概念
基于键值对key-value的数据库,value可以为sting、hash、list、set、zset等多种数据结构。提供键过期,发布订阅,事务,流水线等功能。默认数据库有16个,使用select index 进行选择数据库 0-15
特性
- 速度快。数据存储在内存中。QPS=10万/s
- 单线程,避免多线程竞争问题,C语言实现。
- 持久化。可以将数据持久化到硬盘
- 主从复制。实现多个相同数据的redis副本
- 高可用和分布式。哨兵机制实现高可用,保证Redis节点故障发现和自动转移
使用场景
- 缓存:合理使用缓存加快数据访问速度,降低后端数据源压力
- 排行榜:按照热度排名,按照发布时间排行,主要用到列表和有序集合
- 计数器应用:视频网站播放数,网站浏览数,使用 redis 计数
- 社交网络:赞、踩、粉丝、下拉刷新
- 消息队列:发布和订阅
全局命令
查看所有键:keys *
键总数: dbsize //如果存在大量键,线上禁止使用此指令
检查键是否存在:exists key //存在返回 1,不存在返回 0
删除键:del key //返回删除键个数,删除不存在键返回 0
键过期:expire key seconds //设置键的过期时间(单位:秒) ttl:查看剩余的过期时间
值的数据结构类型:type key //键不存在返回 none
值的类型
字符串 String
存储结构
可以是字符串、xml、Json、数字、二进制。最大不能超过512M。
存取值
设置值:set age 18 ex 10 (键的存活时间为10秒)
获取值: get age
批量设置值:mset country china city sz
批量获取值:mget country city 使用mget= 1次网络请求+redis内部n次查询
计数
自加:
incr age // age的值必须为整数 非整数返回错误,无age键从0自增返回1
incrby age 2 // 自增2
Incrbyfloat score 1.1 // 浮点型自增
自减:
decr age // 减1
decrby age 2 // 自减2
其它
append 追加指令:append keyName value
字符串长度:strlen keyName // 每个中文占用3个字节
截取字符串:getrange keyName 2 4 // 从下标0开始计算截取[2,4]。截取之后,原数据不变
内部编码:object encoding keyName
键值设计
业务名:对象名:id:[属性] order:user:1:age
哈希Hash
存储结构
一个String类型的filed和value的映射表,适用于存储对象
存取值
存值:
hset key filed value
hmset key filed value filed2 value ...// 批量设置值
取值:
hget key filed
hmget key filed filed2 ... // 批量取值
删值:hdel key filed
判断filed是否存在:hexists key filed
获取key所有的属性:hkeys key
获取key所有的值:hvals key
计数
增加:
hincrby key value 1 // value+1
hincrbyfloat key value 2.1 //浮点型+2.1
使用场景
可以将关系型数据表的数据转换成redis的hash进行存储。
列表List
存储结构
存储多个有序的字符串,一个列表最多可存储2的32次方减1个元素,可以在列表左右两边进行插入。
存取值
添加:
rpush key a b c ... // 往右边依此插入a b c,返回值3,lrange key 0 -1输出数据 a b c
lpush key a b c d ...// 往左边依此插入a b c d,返回值4,lrange key 0 -1 输出数据 d c b a
linsert key before/after listValue insertValue// 往列表的某个值前/后插入一个值 只按照从左至右的顺序插入一个
查找:
lrange key startPos endPos // 从左到右按照下标输出值。从0开始 0 -1 输出全部
lindex key pos // 返回从左至右下标的元素,从0开始。-1表示最右边的元素,-2右边第二个
llen key // 返回列表的长度
修改:
lset key 2 value // 替换第三个元素的值
删除:
lpop key // 删除最左边的元素
rpop key // 删除最右边的元素
lrem key count value // 删除count个值为value的元素,大于的话就是删除全部。存在值的话会最少会删除一个,count传0删除一个,负数取绝对值。
ltrim key startPos endPos // 只保留开始到结束位置的下标值 从0开始
应用场景
单个键对应多个值的情况,如单个用户多个订单。
集合Set
存储结构
保存多个不重复的元素,最多存2的32次方减1个元素。支持增删改查和集合的交、并、差集的运算。
存取值
exists key // 检查键值是否存在
sadd key a b c // 添加元素
smember key // 获取所有元素
srem key a // 删除a元素
scard key // 计算元素个数
sismember key a // 判断元素是否存在,存在返回1
srandmember key 2 // 随机返回2个元素
spop key 2 // 随机返回2个元素,并且从集合中删除
sinter key1 key2 key3 ... // 返回集合的交集
sunion key1 key2 key3 ...// 返回集合的并集
sdiff key1 key2 // 返回集合的差集 key1-key2
sinterstore key key1 key2 // 将key1和key2的交集保存到key中 sunionstore sdiffstore
应用场景
用户标签,社交,查询共同爱好的人,智能推荐
有序集合Zset
存储类型
存储不可重复的有序的元素,每个元素后面会有一个分值,表示存储的顺序。
存取值
zadd key score member [score member...] // 存储值
zadd key nx score member // key必须不存在
zadd key xx incr score member // key必须存在,增加分数
zrange key 0 -1 withscores // 查看分数与成员名
zcard key // 计算成员个数
zscore key member // 查看成员分数
zrank key member // 返回成员排名,从0开始,分数越高越靠后
zrevrank key member// 反排序 点赞数最高的排名为0
zrem key member member...// 删除成员
使用场景
主要用于排行榜系统。