Redis 数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
String(字符串)
string 是 redis 最基本的类型,一个 key 对应一个 value。不仅是String,也可以是数字。最大能存储 512MB。string 可以包含任何数据。比如jpg图片或者序列化的对象。
命令:set,get,decr,incr,mget
场景:缓存功能:字符串最经典的使用场景,redis最为缓存层,Mysql作为储存层,绝大部分请求数据都是 redis中获取,由于redis具有支撑高并发特性,所以缓存通常能起到加速读写和降低 后端压力的作用。 计数器:视频播放数系统就是使用redis作为视频播放数计数的基础组件。 共享session:出于负载均衡的考虑,分布式服务会将用户信息的访问均衡到不同服务器上, 用户刷新一次访问可能会需要重新登录,为避免这个问题可以用redis将用户session集中管理, 在这种模式下只要保证redis的高可用和扩展性的,每次获取用户更新或查询登录信息 都直接从redis中集中获取。 限速:处于安全考虑,每次进行登录时让用户输入手机验证码,为了短信接口不被频繁访问, 会限制用户每分钟获取验证码的频率。
Hash(哈希)
Redis hash 是一个键值(key=>value)对集合。
Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。每个 hash 可以存储40多亿键值对。
命令:hget,hset,hgetall
场景:存储、读取、修改用户属性
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。一个列表可以包含 40多个亿元素。
命令:lpush,rpush,lpop,rpop,lrange
场景:1、最新消息排行等功能(比如朋友圈的时间线)
2、消息队列
3、关注列表,粉丝列表
Set(集合)
Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。包含 40多个亿元素。
命令:sadd,spop,smembers,sunion
场景:1、共同好友
2、利用唯一性,统计访问网站的所有独立ip
3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐
zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
场景:1、排行榜
2、带权重的消息队列