【后端面经-数据库】Redis详解——Redis基本概念和特点

这篇具有很好参考价值的文章主要介绍了【后端面经-数据库】Redis详解——Redis基本概念和特点。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录
  • 1. Redis基本概念
  • 2. Redis特点
    • 2.1 优点
    • 2.2 缺点
  • 3. Redis的应用场景
  • 面试模拟
  • 参考资料

声明:Redis的相关知识是面试的一大热门知识点,同时也是一个庞大的体系,所涉及的知识点非常多,如果用一篇文章罗列,往往会陷入知识海洋中无法感知其全貌,因此,这段时间我会试着拆分Redis的相关章节,辅以思维导图的形式介绍Redis的相关知识点,知识点范围包括如下几部分
  • Redis基本概念和特点
  • Redis数据结构和底层数据类型
  • Redis持久化(AOF和RDB)
  • Redis集群和高可用性
  • Redis缓存
  • Redis分布式锁
  • Redis实现异步队列
  • Redis运维问题

今天主要介绍的是Redis基本概念和特点。

1. Redis基本概念

最本质的,Redis是一个数据库,作为一个数据库,它和其他数据库自然不会完全相同,如下是它的一些本质特性:

  • C语言开发:这也是它高性能的一个重要原因;
  • 基于key-value键值对存储:键、值都有丰富的数据类型支持
  • 数据存于内存中:这是访问速度快的一个原因;
  • 非关系型数据库:NoSQL,之前所了解的MySQL是关系型数据库的代表。
  • 高性能:C语言开发+数据存于内存
  • 开源

2. Redis特点

2.1 优点

Redis技术之所以被广泛使用,是因为它具有很多优点,如下所示:

  • 访问速度快

    • 访问速度快主要有四个原因:C语言开发+数据存于内存+单线程+非阻塞I/O多路复用;
    • 这也是它被web应用广泛使用、在大厂技术中作为基础的原因之一。
  • 支持丰富的数据类型
    Redis基于键值对完成数据存储,那么对于键key、值value都有相对应的数据类型支持,如下所示:

    • key:只能是字符串类型
    • value:可支持丰富的数据类型,如下所示:
      • 五大基础数据类型
        • 字符串(String):最基础的数据类型,可以是字符串、整数、浮点数、二进制数据。
          • 很常用的数据结构,存储一般数据都会使用。
        • 列表(List):存储有序元素
          • 可在实现消息队列中可使用。
        • 哈希表(Hash):存储键值对集合,也就是整体Redis存储可实现键值对嵌套,从而提高数据存储的灵活性。
          • 可存储用户信息等。
        • 集合(Set):无序、不可重复的元素。
          • 例如标签tag、共同关注等数据信息,就可以使用集合来存储。
        • 有序集合(Sorted Set):可给每个元素设置权重,作为排序依据,同样不可出现重复元素,但是可以有顺序。
          • 在实现排行榜功能中可使用。
      • 高级数据类型(了解即可)
        • 位图(Bitmap)
        • HyperLogLog
        • 布隆过滤器
        • GeoHash
        • Pub/Sub
        • Stream
  • 单线程

    • Redis是单线程的,这是它访问速度快的一个重要原因,因为单线程不需要考虑线程安全问题,也不需要考虑上下文切换的问题,因此,它的访问速度自然会快很多。
    • Redis单线程的一个重要原因:Redis的瓶颈不在于CPU,而是内存和网络带宽,因此,单线程的Redis可以充分利用CPU的性能,从而提高访问速度。
    • Redis4.0的时候,尝试在主线程外开辟后台线程,处理一些较为耗时的操作,如清理脏数据、断开无用链接、删除过期key等,但是这些操作都是在后台线程中完成,不会影响主线程的访问速度。
    • Redis6.0在某种程度上实现了多线程,使用多线程并行处理读写操作和协议分析,对于命令执行部分依然使用单线程保证访问速度。
      • 这种多线程的方式提高了IO效率,解决了Redis性能限制的瓶颈之一。
  • 非阻塞I/O多路复用

    • I/O多路复用指的是:在一个线程中,可以同时监听多个文件描述符,一旦某个文件描述符就绪(可读或可写),就能够通知程序进行相应的读写操作。这样就不会出现“为了等待任意文件的I/O响应而阻塞主线程”。
    • 也许这时候你会问“不对啊,Redis不是单线程的吗?”,是啊,这里所说的多路复用,指的正是上文中Redis6.0使用多线程处理读写操作的技术部分。
    • I/O多路复用的实现方式主要有:selectpollepoll.具体可参考此篇博客:【后端面经-Java】I/O多路复用 简录
  • 支持持久化、分布式系统、事务、主从复制(集群)

    • 这些在后续的学习中都会具体详细解释

2.2 缺点

任何一个技术都不会是完美的,有优点就必然也存在缺点。——鲁迅(:“我没说过”)
Redis的缺点如下所示

  • 瓶颈问题:内存和网络带宽
    • 在分析Redis单线程原因的时候,我们已经提到过Redis的瓶颈问题,主要就是物理内存的容量大小和IO操作的带宽限制。
    • 举个例子:一个数据库就像一个自由职业者,它的赚钱速度(效率)取决于接单速度和完工速度,而Redis就像一个完工速度非常快的自由职业者(访问速度快),且面对着海量的请求,因此,它的技术瓶颈就在于接单速度(IO操作带宽)。不仅如此,它完工速度快是因为把所有东西都堆在房间(内存)里面,因此,它也同样受限于物理房间的大小(物理内存容量)。
  • 不具备自动容错/恢复的能力
    • 主机从机的宕机都会导致前端部分读写请求失败,需要等待机器重启或者手动切换前端的IP才能恢复。
  • 在线扩容难度高
    • 集群容量在后续维护中很难扩容,因此一开始就需要根据使用规模预备合适的容量空间。

3. Redis的应用场景

Redis是Web应用的常用中间件,它的应用场景非常广泛,如下所示:

  • 缓存
    • Redis作为客户端和服务器数据库之间的缓存数据,可以有效减少数据库的访问压力,提高访问速度。
    • 结构图如下所示:
  • 分布式锁
    • Redis可实现分布式锁,解决分布式系统中的并发问题。
  • 简单消息队列
    • Redis提供发布订阅功能和阻塞队列功能,可以满足一般消息队列功能。
  • 网络流量管理
    • 计数器
      • 天然支持,可记录浏览量、点赞了
    • 排行榜
      • Redis中的列表、有序集合可以用于构建排行榜
    • 社交网络
      • 各类数据之间的关联,赞踩比例、共同好友、共同爱好等等可以使用Redis实现。

面试模拟

Q:Redis、内存、磁盘的区别,为什么快为什么慢?
A:Redis是内存数据库,内存是计算机中最快的存储介质,磁盘是最慢的存储介质。Redis快速是因为它将数据存于内存之后,而内存访问可以直接传输到CPU中,磁盘访问则需要通过IO操作先将数据写入内存空间之后然后再传入CPU中。

Q:Redis的数据库类型、存储结构如何?如何实现排行榜功能
A:Redis属于NoSQL数据库,它的存储结构是键值对,其中键的数据类型只支持字符串,而值可以支持丰富的数据类型,包括列表、有序集合、集合、哈希表、字符串等等,通过列表、有序集合等数据结构实现排行榜功能。

Q:Redis是单线程还是单进程?哪些模块是单线程?
A:Redis执行指令的相关模块是单线程,6.0之后,关于网络IO的处理则转为多线程,使用非阻塞IO多路复用提高IO效率文章来源地址https://www.toymoban.com/news/detail-640857.html

参考资料

  1. Redis教程 - Redis知识体系详解
  2. 三万字+八十图,详解Redis五十二问!太全面了!
  3. 妈妈再也不担心我面试被Redis问得脸都绿了

到了这里,关于【后端面经-数据库】Redis详解——Redis基本概念和特点的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 数据库基本概念

    数据库系统的核心和基础是数据模型 。一般来说,数据模型是严格定义的一组概念的集合。这些概念精确地描述了系统的静态特征、动态特征和完整性约束条件。因此 数据模型一般由数据结构、数据操作和完整性约束三部分组成 数据结构 :存储在数据库中对象类型的集合,

    2024年02月04日
    浏览(8)
  • 数据库基本概念和SQL基本语句

    数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。在数据库中,数据通常以表格的形式存储,这些表格包含了行和列。行通常代表记录,而列代表记录中的不同字段。数据库的设计允许对数据进行高效地查询、更新、删除和添加操作。 基本概念: 数据(Da

    2024年04月22日
    浏览(11)
  • Redis 数据库的概念、常用命令

    Redis 数据库的概念、常用命令

    1、关系型数据库 关系型数据库是一个结构化的数据库,创建在关系模型(二维表格模型)基础上,一般面向于记录。 SQL 语句(标准数据查询语言)就是一种基于关系型数据库的语言,用于执行对关系型数据库中数据的检索和操作。 主流的关系型数据库包括 Oracle、MySQL、S

    2024年02月12日
    浏览(5)
  • [Hive的基本概念之---数据库 ]

    目录 前言:  Hive的一些基本概念: 数据库(Database) 服务器创建hive数据库指令: Spring Boot中集成Hive数据库 在application.properties或application.yml文件中配置Hive JDBC连接属性,例如: 在application.properties或application.yml文件中配置MyBatis属性,例如: 创建Mapper接口和映射文件,例如:

    2024年02月13日
    浏览(21)
  • 循序渐进理解数据库基本概念

    1.1、数据库系统概述 基本概念 数据:描述事物的符号记录称作数据,数据是数据库中存储的基本对象,描述事物可以是数字,文字,视频等 数据库:长期存储在计算机内的、有组织的、可共享的大量数据的集合。数据库中的数据按照一定的数据模型组织、描述和存储的,具

    2024年03月14日
    浏览(16)
  • SQL Server数据库基本概念

    SQL Server数据库基本概念

    目录 一.SQL Server数据库基本构成 1.数据 2.数据库管理系统和数据库系统  二.经典的数据模型 三.常用的主流数据库 四.主键与外键 五.数据完整性规则 描述事物的符号记录称之为数据(Date),数据不仅仅包括数字、文字、图形、图像、声音、档案记录等都是数据。在数据库中,数

    2024年02月07日
    浏览(12)
  • 软件设计师学习笔记12-数据库的基本概念+数据库的设计过程+概念设计+逻辑设计

    软件设计师学习笔记12-数据库的基本概念+数据库的设计过程+概念设计+逻辑设计

    目录 1.数据库的基本概念 1.1数据库的体系结构 1.1.1常见数据库 1.1.2分布式数据库的特点 1.1.3分布式数据库的透明性 1.1.4例题 1.2三级模式结构 1.2.1三级模式概念图 1.2.2例题 1.3数据仓库 1.3.1数据仓库的特点 1.3.2数据仓库的过程 1.3.3例题 2.数据库的设计过程 2.1设计过程概念图 2

    2024年02月07日
    浏览(11)
  • 【MySQL】1、MySQL数据库的基本概念

    【MySQL】1、MySQL数据库的基本概念

    数据库的基本概念 1.数据 2.表         将不同的记录组织在一起;用来存储具体数据 3.数据库         表的集合,是存储数据的仓库;以一定的组织方式存储的相互有关的数据集合 4.数据库管理系统         是实现对数据库资源有效组织、管理和存取的系统软件

    2024年02月11日
    浏览(10)
  • 数据库技术的基本概念、原理、方法和技术

    1. DB:数据库,保存一组有组织的数据的容器; 2. DBMS: 数据库管理系统,又称为数据库软件(数据库产品),用于管理DB中的数据; 3. SQL: 结构化查询语言,用于和DBMS通信的语言。 数据库原理是指数据库系统的基本概念和内部工作原理。数据库是用来管理和存储大量数据的系

    2024年02月15日
    浏览(11)
  • redis数据库和MongoDB数据库基本操作

    (1) 设置键值 (2) 读取键值 (3) 数值类型自增1 (4) 数值类型自减1 (5) 查看值的长度 (1)对列表city插入元素:Shanghai Suzhou Hangzhou (2)将列表city里的头部的元素移除 (3) 对一个已存在的列表插入新元素 (4)查看list的值长度 (1) 设置一个hash表,order表里包括的

    2024年02月16日
    浏览(17)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包