搜尋
首頁資料庫RedisRedis選擇單線程的原因是什麼
Redis選擇單線程的原因是什麼May 30, 2023 pm 01:01 PM
redis

一、Redis版本迭代

Redis選擇單線程的原因是什麼

Redis2.6,支援lua腳本;

Redis3.0,支援叢集;

Redis4.0,混合持久化,多執行緒非同步刪除;

Redis5.0,核心程式碼重構;

Redis6.0,多執行緒IO;

Redis7. 0,Function、Multi-part-AOF;

二、Redis4.0為什麼之前一直採用單執行緒?

1、Redis採用單執行緒模型方便開發與維護;

2、單執行緒模型也可以透過IO多路復用和非阻塞IO並發處理多客戶端請求;

3、對Redis來說,主要的效能瓶頸是記憶體和網絡,而不是CPU;

#三、Redis6.0引入多執行緒

Redis6.0之前,Redis從網路IO處理到實際的讀寫指令處理,都是單執行緒的,只不過在資料刪除、資料持久化的時候使用的是多執行緒。

Redis的效能瓶頸主要是網路IO,因此,Redis6.0開始,採用多個IO執行緒來處理網路請求,提高網路請求處理的並行度。

四、Redis主執行緒和IO執行緒是如何完成請求的?

Redis選擇單線程的原因是什麼

1、服務端和客戶端建立socket連接

主執行緒負責建立連接,並把socket放入全域等待佇列,主執行緒通過輪詢的方法將socket連線分配給IO線程。

2、IO線程讀取並解析請求

主線程一旦把socket分配給IO線程,就會進入阻塞狀態,等待IO線程完成客戶端請求,此時,採用多個IO線程並行處理。

3、主執行緒執行請求指令

IO執行緒解析完請求,主執行緒還是會以單執行緒的方式執行這些指令。

4、IO執行緒會寫回socket和主執行緒清空全域佇列

當主執行緒執行完請求指令後,會將結果寫入緩衝區,主執行緒進入阻塞狀態,等待IO執行緒將結果回寫到socket中,並傳回給客戶端。

回寫socket完畢後,主執行緒清空全域佇列。

五、IO多路復用是什麼?

IO多路復用,一種同步的IO模型,實作一個執行緒監視多個檔案句柄,一旦某個檔案句柄就緒就能夠通知到對用的應用程式進行對應的讀寫操作,沒有檔案句柄就緒時,程式就會進入阻塞狀態,釋放CPU資源。

1、IO,作業系統層面指資料在內核態與使用者態之間進行的讀寫操作;

2、多路,多個客戶端socket連線;

3、復用,復用線程;

4、IO多路復用,使用單線程就能夠同時處理多個客戶端socket連線;

客戶端socket對應的檔案描述子FileDescriptor註冊進epoll,epoll會監聽哪些socket有訊息,避免大量的無用操作。

此時socket採用非阻塞模式,整個過程只會在呼叫select、poll、epoll時才會阻塞,收到客戶端訊息不會阻塞,這個行程就會被充分利用起來,這種模式一般稱為事件驅動,也就是reactor反應模式。

採用epoll的方式,最終目的是提升伺服器的吞吐能力。

IO多路復用與epoll函數才是**「Redis為什麼這麼快?」**的直接原因。

以上是Redis選擇單線程的原因是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
es和redis区别es和redis区别Jul 06, 2019 pm 01:45 PM

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

一起来聊聊Redis有什么优势和特点一起来聊聊Redis有什么优势和特点May 16, 2022 pm 06:04 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

实例详解Redis Cluster集群收缩主从节点实例详解Redis Cluster集群收缩主从节点Apr 21, 2022 pm 06:23 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

Redis实现排行榜及相同积分按时间排序功能的实现Redis实现排行榜及相同积分按时间排序功能的实现Aug 22, 2022 pm 05:51 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

详细解析Redis中命令的原子性详细解析Redis中命令的原子性Jun 01, 2022 am 11:58 AM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

一文搞懂redis的bitmap一文搞懂redis的bitmapApr 27, 2022 pm 07:48 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

实例详解Redis实现排行榜及相同积分按时间排序功能的实现实例详解Redis实现排行榜及相同积分按时间排序功能的实现Aug 26, 2022 pm 02:09 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

一起聊聊Redis实现秒杀的问题一起聊聊Redis实现秒杀的问题May 27, 2022 am 11:40 AM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于实现秒杀的相关内容,包括了秒杀逻辑、存在的链接超时、超卖和库存遗留的问题,下面一起来看一下,希望对大家有帮助。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器