在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

Redis是单线程为什么这么快

108次阅读
没有评论

共计 3556 个字符,预计需要花费 9 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家分享的是有关 Redis 是单线程为什么这么快的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。

一.Redis 简介

Redis 是一个开源的内存中的数据结构存储系统,它可以用作:数据库、缓存和消息中间件。

它支持多种类型的数据结构,如字符串(String),散列(Hash),列表(List),集合(Set),有序集合(Sorted Set 或者是 ZSet)与范围查询,Bitmaps,Hyperloglogs 和地理空间(Geospatial)索引半径查询。其中常见的数据结构类型有:String、List、Set、Hash、ZSet 这 5 种。

Redis 内置了复制(Replication),LUA 脚本(Lua scripting),LRU 驱动事件(LRU eviction),事务(Transactions)和不同级别的磁盘持久化(Persistence),并通过 Redis 哨兵(Sentinel)和自动分区(Cluster)提供高可用性(High Availability)。

Redis 也提供了持久化的选项,这些选项可以让用户将自己的数据保存到磁盘上面进行存储。根据实际情况,可以每隔一定时间将数据集导出到磁盘(快照),或者追加到命令日志中(AOF 只追加文件),他会在执行写命令时,将被执行的写命令复制到硬盘里面。您也可以关闭持久化功能,将 Redis 作为一个高效的网络的缓存数据功能使用。

Redis 不使用表,他的数据库不会预定义或者强制去要求用户对 Redis 存储的不同数据进行关联。

数据库的工作模式按存储方式可分为:硬盘数据库和内存数据库。Redis 将数据储存在内存里面,读写数据的时候都不会受到硬盘 I/O 速度的限制,所以速度极快。

(1)硬盘数据库的工作模式:

Redis 是单线程为什么这么快

(2)内存数据库的工作模式:

Redis 是单线程为什么这么快

看完上述的描述,对于一些常见的 Redis 相关的面试题,是否有所认识了,例如:什么是 Redis、Redis 常见的数据结构类型有哪些、Redis 是如何进行持久化的等。

二.Redis 到底有多快?

Redis 采用的是基于内存的采用的是单进程单线程模型的 KV 数据库,由 C 语言编写,官方提供的数据是可以达到 100000+ 的 QPS(每秒内查询次数)。

这个数据不比采用单进程多线程的同样基于内存的 KV 数据库 Memcached 差!

Redis 是单线程为什么这么快

横轴是连接数,纵轴是 QPS。此时,这张图反映了一个数量级,希望大家在面试的时候可以正确的描述出来,不要问你的时候,你回答的数量级相差甚远!

三.Redis 为什么这么快?

1、完全基于内存,绝大部分请求是纯粹的内存操作,非??焖佟J荽嬖谀诖嬷校嗨朴?HashMap,HashMap 的优势就是查找和操作的时间复杂度都是 O(1);

2、数据结构简单,对数据操作也简单,Redis 中的数据结构是专门进行设计的;

3、采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗 CPU,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗;

4、使用多路 I / O 复用模型,非阻塞 IO;

5、使用底层模型不同,它们之间底层实现方式以及与客户端之间通信的应用协议不一样,Redis 直接自己构建了 VM 机制,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求;

以上几点都比较好理解,下边我们针对多路 I/O 复用模型进行简单的探讨:

(1)多路 I/O 复用模型

多路 I / O 复用模型是利用 select、poll、epoll 可以同时监察多个流的 I/O 事件的能力,在空闲的时候,会把当前线程阻塞掉,当有一个或多个流有 I/O 事件时,就从阻塞态中唤醒,于是程序就会轮询一遍所有的流(epoll 是只轮询那些真正发出了事件的流),并且只依次顺序的处理就绪的流,这种做法就避免了大量的无用操作。

这里“多路”指的是多个网络连接,“复用”指的是复用同一个线程。

采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络 IO 的时间消耗),且 Redis 在内存中操作数据的速度非??欤簿褪撬的诖婺诘牟僮鞑换岢晌跋?Redis 性能的瓶颈,主要由以上几点造就了 Redis 具有很高的吞吐量。

四. 那么为什么 Redis 是单线程的?

我们首先要明白,上边的种种分析,都是为了营造一个 Redis 很快的氛围!官方 FAQ 表示,因为 Redis 是基于内存的操作,CPU 不是 Redis 的瓶颈,Redis 的瓶颈最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且 CPU 不会成为瓶颈,那就顺理成章地采用单线程的方案了(毕竟采用多线程会有很多麻烦?。?/p>

看到这里,你可能会气哭!本以为会有什么重大的技术要点才使得 Redis 使用单线程就可以这么快,没想到就是一句官方看似糊弄我们的回答!但是,我们已经可以很清楚的解释了为什么 Redis 这么快,并且正是由于在单线程模式的情况下已经很快了,就没有必要在使用多线程了!

但是,我们使用单线程的方式是无法发挥多核 CPU 性能,不过我们可以通过在单机开多个 Redis 实例来完善!

警告 1:这里我们一直在强调的单线程,只是在处理我们的网络请求的时候只有一个线程来处理,一个正式的 Redis Server 运行的时候肯定是不止一个线程的,这里需要大家明确的注意一下!例如 Redis 进行持久化的时候会以子进程或者子线程的方式执行(具体是子线程还是子进程待读者深入研究);例如我在测试服务器上查看 Redis 进程,然后找到该进程下的线程:

Redis 是单线程为什么这么快

ps 命令的“-T”参数表示显示线程(Show threads, possibly with SPID column.)“SID”栏表示线程 ID,而“CMD”栏则显示了线程名称。

警告 2:在上图中 FAQ 中的最后一段,表述了从 Redis 4.0 版本开始会支持多线程的方式,但是,只是在某一些操作上进行多线程的操作!所以该篇文章在以后的版本中是否还是单线程的方式需要读者考证!

五. 注意点

1、我们知道 Redis 是用”单线程 - 多路复用 IO 模型”来实现高性能的内存数据服务的,这种机制避免了使用锁,但是同时这种机制在进行 sunion 之类的比较耗时的命令时会使 redis 的并发下降。

因为是单一线程,所以同一时刻只有一个操作在进行,所以,耗时的命令会导致并发的下降,不只是读并发,写并发也会下降。而单一线程也只能用到一个 CPU 核心,所以可以在同一个多核的服务器中,可以启动多个实例,组成 master-master 或者 master-slave 的形式,耗时的读命令可以完全在 slave 进行。

需要改的 redis.conf 项:

pidfile /var/run/redis/redis_6377.pid #pidfile 要加上端口号

port 6377 #这个是必须改的

logfile /var/log/redis/redis_6377.log #logfile 的名称也加上端口号

dbfilename dump_6377.rdb #rdbfile 也加上端口号

2、“我们不能任由操作系统负载均衡,因为我们自己更了解自己的程序,所以,我们可以手动地为其分配 CPU 核,而不会过多地占用 CPU,或是让我们关键进程和一堆别的进程挤在一起?!?/p>

CPU 是一个重要的影响因素,由于是单线程模型,Redis 更喜欢大缓存快速 CPU,而不是多核。

在多核 CPU 服务器上面,Redis 的性能还依赖 NUMA 配置和处理器绑定位置。最明显的影响是 redis-benchmark 会随机使用 CPU 内核。为了获得精准的结果,需要使用固定处理器工具(在 Linux 上可以使用 taskset)。最有效的办法是将客户端和服务端分离到两个不同的 CPU 来高校使用三级缓存。

六. 扩展

以下也是你应该知道的几种模型,祝你的面试一臂之力!

1、单进程多线程模型:MySQL、Memcached、Oracle(Windows 版本);

2、多进程模型:Oracle(Linux 版本);

3、Nginx 有两类进程,一类称为 Master 进程 (相当于管理进程),另一类称为 Worker 进程(实际工作进程)。启动方式有两种:

(1)单进程启动:此时系统中仅有一个进程,该进程既充当 Master 进程的角色,也充当 Worker 进程的角色。

(2)多进程启动:此时系统有且仅有一个 Master 进程,至少有一个 Worker 进程工作。

(3)Master 进程主要进行一些全局性的初始化工作和管理 Worker 的工作;事件处理是在 Worker 中进行的。

Redis 是单线程为什么这么快

感谢各位的阅读!关于“Redis 是单线程为什么这么快”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计3556字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 国产特黄视频 | 国产成人教育视频在线观看 | 亚洲av无码之国产精品网址蜜芽 | 亚洲欧美综合乱码精品成人网 | 久久99久久99 | 伊人在线视频观看 | 亚洲av成为人电影 | 亚洲小说综合 | 精品一区二区三区免费毛片爱 | 91香焦国产线观看看免费 | 高清亚洲精品酒店一区二区三区 | 狠狠色噜噜狠狠狠狠97首创麻豆 | 91老司机在线 | 激情啪啪网站 | 亚洲精品一区二区三区不卡 | 一亚洲精品一区 | 在线小毛片| 国产欧美日韩精品综合 | 亚洲狠狠狠一区二区三区 | 国产人妻精品一区二区三区不卡 | 亚洲av日韩av无码污污网站 | 美日韩一级 | 久久久精品国产 | 精品无码成人久久久久久 | 精品少妇高潮 蜜臀 | 久久亚洲色www成人 久久亚洲色www成人男男 | 熟妇高潮喷沈阳45熟妇高潮喷 | 在线观看亚洲天堂 | 日本三级韩国三级美三级91 | 中文字幕精品一区二区2021年 | 免费大黄网站在线看 | 国产99视频精品草莓免视看 | 亚洲图片小说综合 | 伊人久久大香线蕉综合电影网 | 国精产品一区一区三区有限公司杨 | 久久久久琪琪去精品色村长 | 日本视频在线免费 | 中文字幕资源在线 | 午夜欧美成人 | 日本高清乱码中文字幕 | 久久综合中文字幕一区二区三区 |