Redis的数据类型及应用场景

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)

1. String 这个类型,一个 key 对应一个 value;

string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象;
string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB;

最常规的便是set/get操作,一般做一些复杂的计数功能的缓存。

2. hash 是一个 string 类型的 field 和 value 的映射表;

这里value存放的是结构化的对象,比较方便的就是操作其中的某个字段。
每个 hash 可以存储 232 -1 键值对(40多亿)

在做单点登录的时候,就是用这种数据结构存储用户信息,以cookieId作为key,设置30分钟为缓存过期时间,能很好的模拟出类似session 的效果。

3. list 使用List的数据结构;

一个简单的字符串列表,按照插入顺序排序
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)

可以做简单的消息队列的功能。另外还有一个就是,做基于redis的分页功能,性能极佳,用户体验好。

4. set 因为set堆放的是一堆不重复值的集合;

是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)

所以可以做全局去重的功能

为什么不用编程语言自带的Set进行去重?
因为我们的系统一般都是集群部署,使用编程语言本身自带的Set,比较麻烦,难道为了一个做一个全局去重,再起一个公共服务,太麻烦了。

另外,就是利用交集、并集、差集等操作,可以计算共同喜好,全部的喜好,自己独有的喜好等功能。

5. sorted set

sorted set多了一个权重参数score,集合中的元素能够按score进行排列
成员是唯一的,但score却可以重复

可以做排行榜应用,取TOP N操作。另外,参照另一篇《分布式之延时任务方案解析》,该文指出了sorted set可以用来做延时任务。最后一个应用就是可以做范围查找

以上内容希望帮助到大家,你有什么好的应用场景也欢迎留言互动!

另外,关注公众号:来思Go,回复关键字:算法。即可获取大厂算法学习资料包!


【来思Go】,Let's Go!

专注分享技术干货,欢迎关注留言交流学习!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值