搜尋
首頁資料庫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刪除
REDIS:超越SQL- NOSQL的觀點REDIS:超越SQL- NOSQL的觀點May 08, 2025 am 12:25 AM

Redis超越SQL數據庫的原因在於其高性能和靈活性。 1)Redis通過內存存儲實現極快的讀寫速度。 2)它支持多種數據結構,如列表和集合,適用於復雜數據處理。 3)單線程模型簡化開發,但高並發時可能成瓶頸。

REDIS:與傳統數據庫服務器的比較REDIS:與傳統數據庫服務器的比較May 07, 2025 am 12:09 AM

Redis在高並發和低延遲場景下優於傳統數據庫,但不適合複雜查詢和事務處理。 1.Redis使用內存存儲,讀寫速度快,適合高並發和低延遲需求。 2.傳統數據庫基於磁盤,支持複雜查詢和事務處理,數據一致性和持久性強。 3.Redis適用於作為傳統數據庫的補充或替代,但需根據具體業務需求選擇。

REDIS:功能強大的內存數據存儲的簡介REDIS:功能強大的內存數據存儲的簡介May 06, 2025 am 12:08 AM

Redisisahigh-performancein-memorydatastructurestorethatexcelsinspeedandversatility.1)Itsupportsvariousdatastructureslikestrings,lists,andsets.2)Redisisanin-memorydatabasewithpersistenceoptions,ensuringfastperformanceanddatasafety.3)Itoffersatomicoper

Redis主要是數據庫嗎?Redis主要是數據庫嗎?May 05, 2025 am 12:07 AM

Redis主要是一個數據庫,但它不僅僅是數據庫。 1.作為數據庫,Redis支持持久化,適合高性能需求。 2.作為緩存,Redis提升應用響應速度。 3.作為消息代理,Redis支持發布-訂閱模式,適用於實時通信。

REDIS:數據庫,服務器還是其他?REDIS:數據庫,服務器還是其他?May 04, 2025 am 12:08 AM

redisisamultifaceTedToolThatServesAsAdatabase,server和more.itfunctionsasanin-memorydatastrustore,supportsvariousDataStructures,and CanbeusedAsacache,MessageBroker,sessionStorage,sessionStorage,sessionstorage,andford forderibedibedlocking。

REDIS:揭示其目的和關鍵應用程序REDIS:揭示其目的和關鍵應用程序May 03, 2025 am 12:11 AM

Redisisanopen-Source,內存內部的庫雷斯塔氏菌,卡赫和梅斯吉級,excellingInsPeedAndVersatory.itiswidelysusedforcaching,Real-Timeanalytics,Session Management,Session Managements,and sessighterboarderboarderboardobboardotoitsssupportfortfortfortfortfortfortfortfortorvortfortfortfortfortfortforvortfortforvortforvortforvortfortforvortforvortforvortforvortdatastherctuct anddatataCcessandcessanddataaCces

REDIS:鍵值數據存儲的指南REDIS:鍵值數據存儲的指南May 02, 2025 am 12:10 AM

Redis是一個開源的內存數據結構存儲,用作數據庫、緩存和消息代理,適合需要快速響應和高並發的場景。 1.Redis使用內存存儲數據,提供微秒級的讀寫速度。 2.它支持多種數據結構,如字符串、列表、集合等。 3.Redis通過RDB和AOF機制實現數據持久化。 4.使用單線程模型和多路復用技術高效處理請求。 5.性能優化策略包括LRU算法和集群模式。

REDIS:緩存,會話管理等REDIS:緩存,會話管理等May 01, 2025 am 12:03 AM

Redis的功能主要包括緩存、會話管理和其他功能:1)緩存功能通過內存存儲數據,提高讀取速度,適用於電商網站等高頻訪問場景;2)會話管理功能在分佈式系統中共享會話數據,並通過過期時間機制自動清理;3)其他功能如發布-訂閱模式、分佈式鎖和計數器,適用於實時消息推送和多線程系統等場景。

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脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)