文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Redis常用数据结构介绍和业务应用场景分析

2024-12-02 03:48

关注

Strings字符串、数字

String是redis中最基础的数据结构,你可以把它用作缓存最基础的kv(key-value)类型的缓存(value最大为512MB),只需要把需要缓存的对象进行string的编解码即可。另外String也可以保存数值类型的数据,就可以来实现计数功能(redi提供了incr等原子操作)

常见应用场景

List

List列表更多的时候是把它当成队列使用(最大2^32 - 1个元素),使用入队出队功能,如果来使用它作为各种列表的话,很多时候不具备防重功能在使用的时候不是很方便。

常见应用场景

Set

Set是一种无序不重复的集合,添加删除检查是否存在都是O(1)的时间复杂度。

Sorted Set

Sorted Set是结合了List和Set的一种数据结构,有序(按照元素score排序)的不重复(元素key不重复)的集合,Sorted Set是在业务开发中非常常用的数据结构(比List和Set应用面更广),因为在实际需求中,存在非常多的列表场景,比如视频列表、评论列表、关注列表、点赞列表、排行榜等等各种列表,每个列表都要按照一定规则排序,并且大部分都不能重复,所以使用Sorted Set就非常合适。

常见应用场景

Hash

hash是一个map结构,可以像存储对象的多个字段一样存储一个key的多类数据。

常见应用场景

PubSub

redis中的pub/sub可以实现广播功能,类似rocketmq中的broadcast

常见应用场景

其他数据结构

除了上述最基本的数据结构外,redis还提供了一些其他的数据结构,有的是需要安装相关redis stack来使用的。

bitmap

bitmap本质上还是使用的string字符串,不过可以通过bit来进行操作,把这个key的value值想象成bit组成的数组。

常见应用场景

bloomfilter

bloomfilter(也叫布隆过滤器)可以理解成一种特殊的set集合,它可以用来判断一个值是否在这个集合中,不过不同于普通的set,它的判断存在一定误判的可能(假阳性),如果bloomfilter判断一个值不在这个集合中,那么一定不在,但是如果判断在,那么有可能不在。

常见应用场景

减少请求量、缓存穿透量: 比如为了防止大量请求查询缓存不存在穿透到数据库中查询,我们可以在缓存查询前加一层布隆过滤器的查询,如果不在布隆过滤器中,说明数据肯定不在数据库和缓存中,就不需要继续查询了。

hyperloglog

hyperloglog是一种概率性的去重计数数据结构,可以实现一定精度的去重计数

常见应用场景

geohash

geohash可以实现距离计算、距离查询等地理位置相关的功能

常见应用场景

来源:今日头条内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯