Redis为什么快

用了那么久的redis,突然意识到这个问题答不上来,只知道内存数据库,内存的读写性能快于磁盘。

1. 内存存储

Redis 是一个基于内存的数据库,它将所有的数据都保存在内存中,这使得读取的速度非常快。内存读写速度远超于传统磁盘 I/O操作,因此Redis在处理大量数据时能够保持极高的性能。

2. 数据结构

Redis 的数据结构: 字符串(String)、列表(List)、集合(Set)、哈希(Hash)、有序集合(Zset)。这些数据结构的底层实现较为高效。

1. 字符串(String)

Redis使用的是自己构造的 简单动态字符串(SDS),相比于C语言的字符串,不仅能保存文本数据,也可以保存二进制数据,并且获取字符串长度复杂度为O(1)。

应用场景

需要存储常规数据的场景,比如缓存session。

需要计数的场景,比如用户单位时间的请求数,简单限流

分布式锁,命令 setnx

2. 列表(List)

主要实现为双向链表,支持反向查询和遍历。

应用场景

消息流,比如最新文章,最新动态

3. 哈希(Hash)

哈希是String类型的field-value 键值对映射表,适合用于存储对象,后续操作可以直接修改对象中的某个字段。

应用场景

对象存储场景,比如用户信息,商品信息等

4. 集合(Set)

集合是无序但唯一的,类似于Java的Set。

应用场景

存放的是不能重复的数据,比如点赞只能点一次

5. 有序集合(Zset)

增加了一个权重参数,使得集合中的元素可以按照分数给元素排序,还可以通过分数范围获取元素。

依赖于跳表skipList和哈希表,跳表支持快速的插入删除和查找操作。哈希表用于存储分数。便于快速根据分数排序和范围查询。

应用场景

需要根据某个分数排序的场景,比如微信步数根据步数排序,直播间打赏榜等。

 

3. 单线程模型和IO多路复用

Redis采用的单线程模型,基于Reactor模式设计开发了一套高效的事件处理模型。这套事件模型对应的是Redis中的文件事件处理器,是单线程运行的。虽然看起来限制了性能,实例上因为Redis的操作都是内存操作,没有太复杂的计算或者IO操作,避免了多线程之间的上下文切换和同步问题。减少开销。

单线程模型下,通过IO多路复用来监听客户端的请求,只有在有数据可读和可写时才会有IO操作,从而能提高系统的吞吐量和响应速度。

 

既然Redis那么快,为什么不将Redis作为主数据库。

主要原因是成本太高,而且Redis提供的数据持久化仍然有丢失数据的风险。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/11978.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

#自学习# 记一次py脚本打开浏览器页面

在项目总结中,遇到系统后台利用浏览器拉起一个已知路径页面的需求,趁着机会整理下。实现起来比较简单,浏览器默认谷歌。 一、技术原理 Selenium:Selenium 是一个用于自动化 Web 浏览器的工具,可模拟用户在浏览器中的各…

socket接口定义范围及操作

Socket接口,也称为套接字接口,是用于实现网络通信的一种编程接口。它定义了一系列的操作和函数,允许应用程序通过网络进行数据传输。 Socket接口不仅仅局限于特定的操作系统或网络协议,而是在多种网络环境中通用,包括但…

Python面试题【数据结构和算法部分101-130】

Python面试题【数据结构和算法部分101-130】 Python面试题【数据结构和算法部分101-130】 Python面试题【数据结构和算法部分101-130】 问题:如何在Python中实现二分查找? 答案: def binary_search(arr, target):low, high 0, len(arr) - 1…

奔向光明阿波罗(五)

下半场的艰难曙光 有“中国无人驾驶黄埔军校”之称的百度,最初的雄心是给未来的智能汽车安上一颗“百度之心”,取得类似于“Intel Inside“的品牌强强联合效果。阿波罗希望为汽车行业的玩家提供一个“开放、完整、安全”的开源平台,帮助他们结…

正则表达式中的$分组使用示例

正则表达式中的 $ 符号通常用于表示字符串的结束位置,但当你在替换操作或者某些特殊上下文中提到 $ 后跟数字(如 $1, $2, etc.),这并不表示结束位置,而是引用之前正则表达式捕获组的内容。 以下是使用 $ 引用捕获组的…

计算机视觉与深度学习实战:以Python为工具,基于块匹配的全景图像拼接

注意:本文的下载教程,与以下文章的思路有相同点,也有不同点,最终目标只是让读者从多维度去熟练掌握本知识点。 下载教程:计算机视觉与深度学习实战-以MATLAB和Python为工具_基于块匹配的全景图像拼接_项目开发案例教程.pdf 计算机视觉作为人工智能领域的一个重要分支,旨在…

成都百洲文化传媒有限公司怎么样?靠谱吗?

在数字化浪潮席卷全球的今天,电商行业正以前所未有的速度蓬勃发展。作为这一变革的积极参与者和推动者,成都百洲文化传媒有限公司以其专业的电商服务,正逐渐成为行业内的佼佼者。 一、公司简介 成都百洲文化传媒有限公司自成立以来&#xff…

邦芒宝典:离职前一定要做的几件事帮你刷爆好感

​​这个问题,关键还是要看这位有本事的员工的职业素养如何。虽说工有本事的员工往往都会具备比较高的职业素养,比如强专业能力、强沟通、强执行、正确的价值观与职业操守等等,但也可能有些人能力是不错,但素养比较低,…

MyBatis的创建和测试

创建项目点击Spring Initializr然后点击next 点击SQL 选择里面的Mybatis Framework和Mysql Driver 按如下图片创建项目 user表中的数据 #下面这些内容是为了让MyBatis映射 #指定Mybatis的Mapper文件 mybatis.mapper-locationsclasspath:mappers/*xml #指定Mybatis的实体目录 my…

【Java】IDEA自动生成类图和时序图

【Java】IDEA自动生成类图和时序图 idea 的强大之处在于此,它包含了很多小插件,我们不需要再次下载相关插件,只需要在idea中小小的设置一下就可以了,下面是设置方法,我用的是idea2020版本 打开设置File -> Settings->Diagr…

Netty-面试题(中)(五十)

关于零拷贝和堆外内存 Java在将数据发送出去的时候,会先将数据从堆内存拷贝到堆外内存,然后才会将堆外内存再拷贝到内核态,进行消息的收发,代码如下: 所以,我们发现,假如我们在收发报文的时候使用直接内存&…

工业互联网网络安全如何保障

随着工业4.0时代的到来,工业互联网(IIoT)成为了推动制造业数字化转型的重要力量。然而,随着工业互联网的快速发展,其网络安全问题也日益凸显。保障工业互联网网络安全,不仅关系到企业的正常运营&#xff0c…

Gin框架返回Protobuf类型:提升性能的利器

在构建高效、高性能的微服务架构时,数据序列化和反序列化的性能至关重要。Protocol Buffers(简称Protobuf)作为一种轻量级且高效的结构化数据存储格式,已经在众多领域得到广泛应用。Gin框架作为Go语言中流行的Web框架,…

【Linux】进程信号(2万字)

目录 前言 一、生活角度的信号 1.1、我们来见一见信号: 1.2、模拟一下 kill 指令 二、信号的处理 三、产生信号的5种方法 3.1、kill命令 3.2、键盘可以产生信号 3.3、3种系统调用 3.4、软件条件 3.5、异常 四、比较 core 和 Term 五、键盘信号产生 六…

SSL/TLS协议信息泄露漏洞(CVE-2016-2183)解法

1.运行gpedit.msc,进入本地组策略编辑器。 2. 本地组策略编辑器-->计算机配置-->管理模板-->网络-->SSL配置设置-->启用“SSL密码套件顺序”。 3. 将原有的密码套件值清空,拷入下面的值,保存设置,并重启服务器即…

让爱回家:家政服务中的情感与温度

一、引言 在繁忙的现代生活中,家政服务已逐渐成为许多家庭不可或缺的一部分。然而,家政服务并非仅仅是简单的家务劳动,它更是一次情感的交流和温度的传递。本文将探讨家政服务中的情感与温度,让爱通过这一平凡而重要的职业回到每…

EmotiVoice 实时语音合成TTS;api接口远程调用

参考:https://github.com/netease-youdao/EmotiVoice 测试整体速度可以 docker安装: 运行容器:默认运行了两个服务,8501 一个streamlit页面,另外8000是一个api接口服务 docker run -dp 8501:8501 -p 8250:8000 syq163/emoti-voice:latest##gpu运行 (gpu运行遇到CUDA er…

ios与android上音频格式的推荐

首先贴一张官方对于ios与android上音频格式的推荐: 这里只给出了推荐格式,一般我们在实际运用中会使用如下方式: 一、IOS与安卓各一套:音乐:都使用MP3 音效:ios用caf Android用ogg 二、使用通用的MP3格式…

【Linux系统编程】第十八弹---进程状态(上)

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、操作系统进程 1.1、进程背景 1.2、进程如何在CPU上运行的? 1.2、进程状态 2、Linux的进程状态 2.1、如何描…

js车牌识别接口开发示例、Vin解析接口

首先,我们来看一下车牌识别的功能一般都应用在哪些地方:第一种就是各种停车位置在进行管理的时候,一般会采用OCR技术来帮助系统识别车牌并进行管理;第二种就是汽车保险管理工作的场景,当工作人员对车辆进行保险勘察的时…