一文搞定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 延迟消息队列
总结
更多精彩推荐
点分享 点点赞 点在看
关注公众号:拾黑(shiheibook)了解更多
[广告]赞助链接:
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
关注网络尖刀微信公众号
随时掌握互联网精彩
随时掌握互联网精彩
赞助链接
排名
热点
搜索指数
- 1 准确把握守正创新的辩证关系 7993278
- 2 中国黄金原董事长家搜出大量黄金 7986318
- 3 空调英文不会男生盯着考场空调看 7830731
- 4 消费品以旧换新“加速度” 7750081
- 5 被铁路售票员的手速惊到了 7694552
- 6 网红赤木刚宪爆改赵露思 7508514
- 7 县委原书记大搞“刷白墙”被通报 7417150
- 8 山姆代购在厕所分装蛋糕 7378651
- 9 马龙刘诗雯穿正装打混双 7233344
- 10 刘强东提前发年终奖 7126009