iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Redis高效率原因及数据结构分析
  • 560
分享到

Redis高效率原因及数据结构分析

2024-04-02 19:04:59 560人浏览 薄情痞子
摘要

目录1、什么是Redis?它主要用来干什么的?2、redis为什么这么快?基于内存存储实现高效的数据结构1、SDS简单动态字符串2、字典3、跳表合理的数据编码合理的线程模型1、I/O

1、什么是redis?它主要用来干什么的?

Redis,英文全称是Remote Dictionary Server(远程字典服务),是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的api

Mysql数据库不同的是,Redis的数据是存在内存中的。它的读写速度非常快,每秒可以处理超过10万次读写操作。因此redis被广泛应用于缓存,另外,Redis也经常用来做分布式。除此之外,Redis支持事务、持久化、lua 脚本、LRU 驱动事件、多种集群方案。

知道redis是什么后,接下来我们来说一说redis为什么这么快。

2、redis为什么这么快?

在这里插入图片描述

我们来一个一个说明!

基于内存存储实现

计算机专业的同学我们都知道内存读写是要比磁盘快很多的,Redis是基于内存实现的数据库,相对于数据存在磁盘的mysql等数据库,省去了磁盘I/O的消耗。

高效的数据结构

我们都知道,mysql索引为了提高效率,选择了B+树的数据结构,对于一个应用场景来说合理的数据结构可以让你的应用或者程序更快。我们来看看Redis的数据结构–内部编码图:

在这里插入图片描述

String : 动态字符串SDS
List: 双端链表LinkedList+压缩链表ziplist
Hash: 压缩链表ziplist+字典哈希表hashtable
Set: hashtable(+inset)
Zset: 压缩链表ziplist+跳表skiplist

我们来说一说这几种内部编码:

1、SDS简单动态字符串

在这里插入图片描述
我们来和C语言中的char[ ]对比下

字符串长度处理: Redis获取字符串长度,时间复杂度为O(1),而C语言中,需要从头遍历,复杂度为O(N)。

空间预分配: 字符串修改越频繁的话,内存分配就越频繁,就会很消费性能,而SDS修改和空间扩充,会额外分配未使用的空间,减少性能损耗。

惰性空间释放: SDS缩短时,不是回收多余的内存空间,而是free记录下多余的空间,后续有变更,直接使用free中记录的空间,减少分配。

二进制安全: Redis可以存储一些二进制数据,在C语言中字符串遇到'/0'会结束,而SDS中标志字符串结束的是len属性。

2、字典

Redis 作为 K-V 型内存数据库,所有的键值就是用字典来存储。字典就是哈希表,比如HashMap,通过key就可以直接获取到对应的value。而哈希表的特性,在O(1)时间复杂度就可以获得对应的值。

3、跳表

在这里插入图片描述

跳表是Redis特有的数据结构,就是在链表的基础上,增加多级索引提升查找效率。
跳表支持平均O(logN),最坏O(N)复杂度的节点查找,还可以通过顺序性操作。

合理的数据编码

Redis 支持多种数据数据类型,每种基本类型,可能对多种数据结构。什么时候,使用什么样数据结构,使用什么样编码,是redis设计者总结优化的结果。

String: 如果存储数字的话,是用int类型的编码;如果存储非数字,小于等于39字节的字符串,是embstr;大于39个字节,则是raw编码。
List: 如果列表的元素个数小于512个,列表每个元素的值都小于64字节(默认),使用ziplist编码,否则使用linkedlist编码
Hash: 哈希类型元素个数小于512个,所有值小于64字节的话,使用ziplist编码,否则使用hashtable编码。
Set: 如果集合中的元素都是整数且元素个数小于512个,使用intset编码,否则使用hashtable编码。
Zset: 当有序集合的元素个数小于128个,每个元素的值小于64字节时,使用ziplist编码,否则使用skiplist(跳跃表)编码。

合理的线程模型

1、I/O多路复用

在这里插入图片描述
多路I/O复用技术可以让单个线程高效的处理多个连接请求,而Redis使用用epoll作为I/O多路复用技术的实现。并且,Redis自身的事件处理模型将epoll中的连接、读写、关闭都转换为事件,不在网络I/O上浪费过多的时间。

2、什么是I/O多路复用?

I/O : 网络 I/O
多路 : 多个网络连接
复用: 复用同一个线程。
IO多路复用其实就是一种同步IO模型,它实现了一个线程可以监视多个文件句柄;一旦某个文件句柄就绪,就能够通知应用程序进行相应的读写操作;而没有文件句柄就绪时,就会阻塞应用程序,交出cpu。

3、单线程模型

Redis是单线程模型的,而单线程避免了CPU不必要的上下文切换和竞争锁的消耗。也正因为是单线程,如果某个命令执行过长(如hgetall命令),会造成阻塞。Redis是面向快速执行场景的数据库。,所以要慎用如smembers和lrange、hgetall等命令。

Redis 6.0 引入了多线程提速,它的执行命令操作内存的仍然是个单线程。

虚拟内存机制

redis直接自己构建了VM机制,不会像一般的系统会调用系统函数处理,会浪费一定的时间去移动和请求。

Redis的虚拟内存机制是啥呢?

虚拟内存机制就是暂时把不经常访问的数据(冷数据)从内存交换到磁盘中,从而腾出宝贵的内存空间用于其它需要访问的数据(热数据)。通过VM功能可以实现冷热数据分离,使热数据仍在内存中、冷数据保存到磁盘。这样就可以避免因为内存不足而造成访问速度下降的问题。

以上就是Redis高效原因及数据结构分析的详细内容,更多关于Redis的资料请关注编程网其它相关文章!

--结束END--

本文标题: Redis高效率原因及数据结构分析

本文链接: https://www.lsjlt.com/news/136879.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis高效率原因及数据结构分析
    目录1、什么是redis?它主要用来干什么的?2、redis为什么这么快?基于内存存储实现高效的数据结构1、SDS简单动态字符串2、字典3、跳表合理的数据编码合理的线程模型1、I/O...
    99+
    2024-04-02
  • AS400处理数据高效率的几个原因分别是什么
    本篇文章为大家展示了AS400处理数据高效率的几个原因分别是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。AS400传统写法比开放平台数据库执行SQL效率高的几...
    99+
    2024-04-02
  • Golang Map分析:高效灵活的键值对数据结构
    解密Golang中的Map:灵活高效的键值对 引言:在Golang中,Map是一种非常常用的数据结构,用于存储键值对(key-value)的集合。它提供了快速的插入、删除和查找操作,是处理大量数据时提高效率的...
    99+
    2024-01-16
    解密 Golang map
  • 分布式架构Redis中有哪些数据结构及底层实现原理
    目录引言1、面试官:我看你提到,项目中使用了Reids作为缓存,为什么是Reids而不是其他,Redis有什么优势吗?2、面试官:刚刚你提到Redis是单线程,为什么单线程模型的 R...
    99+
    2024-04-02
  • Redis中数据结构的底层实现分析
    Redis中数据结构的底层实现分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、概述Redis是一个开源的使用ANSI C...
    99+
    2024-04-02
  • Redis数据结构类型实例代码分析
    这篇“Redis数据结构类型实例代码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Redis数据结构类型实例代码分析”文...
    99+
    2023-07-05
  • Redis数据结构原理是什么
    本篇内容介绍了“Redis数据结构原理是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!RedisDbRedis服务器默认有16个数据库,...
    99+
    2023-07-05
  • redis中hash数据结构及说明
    目录hash的数据结构ziplist底层实现字典底层实现扩容缩容总结hash的数据结构 hash底层数据结构的实现包括两种:ziplist和字典当保存的所有键值对字符串长度小于 64 字节并且键值对数量小于 512 时使...
    99+
    2023-01-28
    redis hash数据结构 redis hash hash数据结构
  • Redis中数据结构与数据操作的示例分析
    小编给大家分享一下Redis中数据结构与数据操作的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Redis完成数据操作的...
    99+
    2024-04-02
  • redis数据类型及结构特性
    redis支持多种数据类型,每种类型具有独特结构:字符串:字节数组,可追加、修改和获取范围数据。列表:有序字节数组序列,可添加/弹出元素,获取/修改索引元素。哈希:键值对集合,可设置/获...
    99+
    2024-04-19
    redis 键值对
  • C语言汇编分析传递结构体指针比传递结构体变量高效的深层原因
    目录前言传递结构体变量传递结构体指针总结前言 先声明下观点:当有少量结构体成员时,传递结构体指针和结构体变量的差距不大;当有大量结构体成员时,随着成员越来越多,传递指针的效率也越来越...
    99+
    2022-11-13
    C语言汇编分析 C语言传递结构体指针 C语言传递结构体变量
  • Redis的查询很快的原因解析及Redis如何保证查询的高效
    目录Redis如何保证高效的查询效率为什么Redis比较快Redis中的数据结构1、简单动态字符串2、链表3、字典4、跳表5、整数数组6、压缩列表为什么单线程还能很快基于多路复用的高...
    99+
    2024-04-02
  • Go反射底层原理及数据结构解析
    目录1. 反射的引入与介绍2. 反射的数据结构3. 如何通过反射对象来修改原数据对象的值?1. 反射的引入与介绍 在计算机科学中,反射是指计算机程序在运行时(Run time)可以访...
    99+
    2024-04-02
  • NumPy 到底能否提高数据分析的效率?
    NumPy 是 Python 中的一个重要的数据处理库,它能够提供高效的数值计算和大规模数据处理的支持。这使得 NumPy 在数据分析领域中得到了广泛应用。但是,NumPy 到底能否提高数据分析的效率呢?本文将会探讨这个问题。 首先,让我们...
    99+
    2023-08-31
    bash numy http
  • 怎么使用numpy提高Python数据分析效率
    今天小编给大家分享一下怎么使用numpy提高Python数据分析效率的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、数组初...
    99+
    2023-07-06
  • Redis的数据结构及应用场景
    一. 谈谈对redis的理解,它的应用场景。Redis是一个key-value存储系统,它支持存储的value类型包括string字符串、list链表、set集合、sorted Set有序集合和hash哈希等数据类型。这些数据类型都支持pu...
    99+
    2023-06-02
  • C++数据结构分析多态的实现与原理及抽象类
    目录多态的概念虚函数多态构成的条件C++11override和final重载、重写和重定义(隐藏)抽象类多态的原理虚函数表原理单继承和多继承的虚表单继承的虚表多继承的虚函数表几个值得...
    99+
    2024-04-02
  • PHP数据库接口的作用及原因分析
    标题:PHP数据库接口的作用及原因分析 在Web开发领域中,数据库是至关重要的一部分,而PHP作为一种被广泛应用于服务器端开发的语言,与数据库之间的交互也显得尤为重要。为了方便PHP与...
    99+
    2024-03-12
    接口 数据库 php sql语句 防止sql注入
  • Python高级数据结构与算法实例分析
    本文小编为大家详细介绍“Python高级数据结构与算法实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python高级数据结构与算法实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、简介我们将从以...
    99+
    2023-07-05
  • 分析和数据科学怎么提高业务效率
    这篇文章主要介绍“分析和数据科学怎么提高业务效率”,在日常操作中,相信很多人在分析和数据科学怎么提高业务效率问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析和数据科学怎么提...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作