百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

Redis数据结构总结——面试最常问到的知识点

mhr18 2025-08-06 21:31 2 浏览 0 评论

Redis作为主流的nosql存储,面试时经常会问到。其主要场景是用作缓存,分布式锁,分布式session,消息队列,发布订阅等等。其存储结构主要有String,List,Set,Hash,Sort Set。

存储结构

String

String是最常应用的存储结构,它的底层是SDS结构实现。SDS结构如下:

  • len:记录字符串长度
  • alloc:记录分配字符数组的空间大小
  • flag:标志位,用于标识SDS类型
  • buf:实际存储字符串内容的字节数组

其主要应用场景:

  • 缓存用户信息:存储一个json的序列化数据。
  • 计数器(点赞数、访问量):可以通过INCR/INCRBY命令来进行数值的增加。
  • 分布式锁
  • 会话存储

SET GET

APPEND

INCR INCRBY

List

List采用的是双向链表实现,支持快速的头尾插入和删除。

  • prev:前一个节点指针
  • next:后一个节点指针
  • value:值

其主要应用场景:

  • 消息队列:LPUSH入队,RPOP出队。或RPUSH入队,LPOP出队。
  • 最新消息列表
  • 用户操作历史
  • 实现栈和队列:栈:LPUSH入队,LPOP出队。或RPUSH入队,RPOP出队。队列:LPUSH入队,RPOP出队。或RPUSH入队,LPOP出队。

LPUSH RPUSH LPOP RPOP

Hash

hash采用的是字典(Dict)的存储结构。有点类似于HashMap,其解决哈希冲突的方式是链地址法。

扩容与缩容(rehash):当元素满了,就会2倍进行扩容。但是如果正在进行bgsave时,不会进行扩容(减少copy on write次数)。当元素数量达到数组长度的5倍时,强制进行扩容。当元素数量是数组长度的10%时,进行缩容,缩容不受bgsave的影响。

其主要应用场景:

  • 存储对象信息
  • 用户属性管理
  • 购物车
  • 配置信息存储

HSET HGET HGETALL HDEL

SET

SET使用哈希表实现,确保元素的唯一性。

其主要应用场景:

  • 标签系统
  • 好友关系
  • 去重操作
  • 共同关注/粉丝:SINTER 交集

SADD SMEMBERS SISMEMBER SREM

SUNION 并集

SINTER 交集

SDIFF 差集

Sort Set(ZSET)

ZSET是通过哈希表和跳跃表实现的,既保证元素唯一性又维护有序性。

其主要应用场景:

  • 排行榜
  • 优先级队列
  • 延时队列
  • 范围查询

ZADD ZRANGE WITHSCORES ZREVRANGE ZSCORE ZRANK ZRANGEBYSCORE

底层结构

SkipList:跳跃表通过维护一个多级索引结构来实现快速查找。在跳跃表中,每个节点包含一个数据元素和一组指向其他节点的指针。这些指针分布在不同的层级,每个层级的指针数量都比下一层级少。最底层(第0层)包含所有的元素,而最高层则只包含少数几个元素。这样,查找操作可以在高层级开始,快速跳过那些不需要的元素。

ZipList:压缩列表是一种特殊的“双向链表”,但其实并不是链表,而是一段连续的内存空间,可以在任意一端进行压入/弹出操作。

  • zlbytes:存该压缩列表的总字节数,byte即字节
  • zltail:存最后一个节点到压缩列表的实际地址之间的字节数(尾偏移量)
  • zllen:存的是总entry的个数
  • entry:即节点
  • zlend:压缩列表的结束标志,并且值是固定的:0xff

ZipList用于Hash存储的优化。当判断对象的编码如果是REDIS_ENCODING_ZIPLIST就走ziplist添加/修改键值对,否则走hash添加/修改键值对。检查元素长度是否大于512,大于的话需要转码成REDIS_ENCODING_HT使用hash存储。

IntSet:整数集合 IntSet 是 Redis用来保存整数值的集合的一种数据结构,可以用来保存 int 类型数据,并且可以保证不会出现重复元素。因此当一个集合中只包含整数元素且数量不多的时候,Redis 会选择使用整数集合作为底层实现。IntSet 内部其实是一个数组(int8_t coentents[] 数组),而且存储数据的时候是有序的,因为在查找数据的时候是通过二分查找来实现的。

相关推荐

订单超时自动取消业务的 N 种实现方案,从原理到落地全解析

在分布式系统架构中,订单超时自动取消机制是保障业务一致性的关键组件。某电商平台曾因超时处理机制缺陷导致日均3000+订单库存锁定异常,直接损失超50万元/天。本文将从技术原理、实现细节、...

使用Spring Boot 3开发时,如何选择合适的分布式技术?

作为互联网大厂的后端开发人员,当你满怀期待地用上SpringBoot3,准备在项目中大显身手时,却发现一个棘手的问题摆在面前:面对众多分布式技术,究竟该如何选择,才能让SpringBoot...

数据库内存爆满怎么办?99%的程序员都踩过这个坑!

你的数据库是不是又双叒叕内存爆满了?!服务器监控一片红色警告,老板在群里@所有人,运维同事的电话打爆了手机...这种场景是不是特别熟悉?别慌!作为一个在数据库优化这条路上摸爬滚打了10年的老司机,今天...

springboot利用Redisson 实现缓存与数据库双写不一致问题

使用了Redisson来操作Redis分布式锁,主要功能是从缓存和数据库中获取商品信息,以下是针对并发时更新缓存和数据库带来不一致问题的解决方案1.基于读写锁和删除缓存策略在并发更新场景下,...

外贸独立站数据库炸了?对象缓存让你起死回生

上周黑五,一个客户眼睁睁看着服务器CPU飙到100%——每次页面加载要查87次数据库。这让我想起2024年Pantheon的测试:Redis缓存能把WooCommerce查询速度提升20倍。跨境电商最...

手把手教你在 Spring Boot3 里纯编码实现自定义分布式锁

为什么要自己实现分布式锁?你是不是早就受够了引入各种第三方依赖时的繁琐?尤其是分布式锁这块,每次集成Redisson或者Zookeeper,都得额外维护一堆配置,有时候还会因为版本兼容问题头疼半...

如何设计一个支持百万级实时数据推送的WebSocket集群架构?

面试解答:要设计一个支持百万级实时数据推送的WebSocket集群架构,需从**连接管理、负载均衡、水平扩展、容灾恢复**四个维度切入:连接层设计-**长连接优化**:采用Netty或Und...

Redis数据结构总结——面试最常问到的知识点

Redis作为主流的nosql存储,面试时经常会问到。其主要场景是用作缓存,分布式锁,分布式session,消息队列,发布订阅等等。其存储结构主要有String,List,Set,Hash,Sort...

skynet服务的缺陷 lua死循环

服务端高级架构—云风的skynet这边有一个关于云风skynet的视频推荐给大家观看点击就可以观看了!skynet是一套多人在线游戏的轻量级服务端框架,使用C+Lua开发。skynet的显著优点是,...

七年Java开发的一路辛酸史:分享面试京东、阿里、美团后的心得

前言我觉得有一个能够找一份大厂的offer的想法,这是很正常的,这并不是我们的饭后谈资而是每个技术人的追求。像阿里、腾讯、美团、字节跳动、京东等等的技术氛围与技术规范度还是要明显优于一些创业型公司...

mysql mogodb es redis数据库之间的区别

1.MySQL应用场景概念:关系型数据库,基于关系模型,使用表和行存储数据。优点:支持ACID事务,数据具有很高的一致性和完整性。缺点:垂直扩展能力有限,需要分库分表等方式扩展。对于复杂的查询和大量的...

redis,memcached,nginx网络组件

1.理解阻塞io,非阻塞io,同步io,异步io的区别2.理解BIO和AIO的区别io多路复用只负责io检测,不负责io操作阻塞io中的write,能写多少是多少,只要写成功就返回,譬如准备写500字...

SpringBoot+Vue+Redis实现验证码功能

一个小时只允许发三次验证码。一次验证码有效期二分钟。SpringBoot整合Redis...

AWS MemoryDB 可观测最佳实践

AWSMemoryDB介绍AmazonMemoryDB是一种完全托管的、内存中数据存储服务,专为需要极低延迟和高吞吐量的应用程序而设计。它与Redis和Memcached相似,但具有更...

从0构建大型AI推荐系统:实时化引擎从工具到生态的演进

在AI浪潮席卷各行各业的今天,推荐系统正从幕后走向前台,成为用户体验的核心驱动力。本文将带你深入探索一个大型AI推荐系统从零起步的全过程,揭示实时化引擎如何从单一工具演进为复杂生态的关键路径。无论你是...

取消回复欢迎 发表评论: