一文搞定Redis五大数据类型及使用场景
字符串
1.1 内部编码
int:8个字节的长整型。 embstr:小于等于39个字节的字符串。 raw:大于39个字节的字符串。
1.2 使用场景
1.2.1 缓存
1.2.2 计数
值不是整数,返回错误 值是整数,返回自增后的结果 key不存在,默认键为0,返回1
1.2.3 共享Session
1.2.4 限速
2.1 内部编码
ziplist(压缩列表):当哈希类型元素个数小于hash-max-ziplist-entries配置(默认512个)同时所有值都小于hash-max-ziplist-value配置(默认64字节)时使用。ziplist使用更加紧凑的结构实现多个元素的连续存储,所以比hashtable更加节省内存。 hashtable(哈希表):当ziplist不能满足要求时,会使用hashtable。
2.2 使用场景
id | name | age |
---|---|---|
1 | Java旅途 | 18 |
hset user:1 name Java旅途 age 18
列表
3.1 内部编码
ziplist(压缩列表):当哈希类型元素个数小于list-max-ziplist-entries配置(默认512个)同时所有值都小于list-max-ziplist-value配置(默认64字节)时使用。ziplist使用更加紧凑的结构实现多个元素的连续存储,所以比hashtable更加节省内存。 linkedlist(链表):当ziplist不能满足要求时,会使用linkedlist。
3.2 使用场景
3.2.1 消息队列
3.2.2 栈
3.2.3 文章列表
集合
4.1 内部编码
intset(整数集合):当集合中的元素都是整数且元素个数小于set-max-intset-entries配置(默认512个)时,redis会选用intset来作为集合的内部实现,从而减少内存的使用。 hashtable(哈希表):当intset不能满足要求时,会使用hashtable。
4.2 使用场景
4.2.1 用户标签
给用户打标签
sadd user:1:tags tag1 tag2
给标签添加用户
sadd tag1:users user:1
sadd tag2:users user:1
sinter user:1:tags user:2:tags
4.2.2 抽奖功能
随机获取count个元素,集合元素个数不变
srandmember key [count]
随机弹出count个元素,元素从集合弹出,集合元素个数改变
spop key [count]
有序集合
5.1 内部编码
ziplist(压缩列表):当有序集合的元素个数小于list-max-ziplist-entries配置(默认128个)同时所有值都小于list-max-ziplist-value配置(默认64字节)时使用。ziplist使用更加紧凑的结构实现多个元素的连续存储,更加节省内存。 skiplist(跳跃表):当不满足ziplist的要求时,会使用skiplist。
5.2 使用场景
5.2.1 排行榜
zadd user:article 0 a
zincrby user:article 1 a
zrevrangebyscore user:article 0 2
zrangebyscore user:article 0 2
5.2.2 延迟消息队列
总结
赞 (0)