搜尋
首頁資料庫Redisredis是單線程還是多線程,為什麼

redis是單線程還是多線程,為什麼

Dec 18, 2020 pm 03:08 PM
redis單執行緒多執行緒

Redis4.0之前是單執行緒運行的;Redis4.0後開始支援多執行緒。 Redis4.0之前使用單執行緒的原因:1、單執行緒模式方便開發和調試;2、Redis內部使用了基於epoll的多路復用;3、Redis主要的效能瓶頸是記憶體或網路頻寬。

redis是單線程還是多線程,為什麼

(學習影片分享:redis影片教學

不同版本的Redis是不同的,在Redis4. 0之前,Redis是單執行緒運行的,但單執行緒並不代表效率低,像Nginx、Nodejs也是單執行緒程序,但是它們的效率並不低。

原因是Redis是基於記憶體的,它的瓶頸在於機器的記憶體、網路頻寬,而不是CPU,在CPU還沒達到瓶頸時機器記憶體可能就滿了、或頻寬達到瓶頸了。因此CPU不是主要原因,那麼自然就採用單線程了,況且使用多執行緒比較麻煩。

但是在Redis4.0的時候,已經開始支援多執行緒了,像是後台刪除等功能。

簡單來說,Redis在4.0之前使用單執行緒的模式是因為以下三個原因:

  • 使用單執行緒模式的Redis,其開發和維護更簡單,因為單線程模式方便開發和調試。

  • 即使使用單執行緒模型也能夠並發地處理多客戶端的請求,主要是因為Redis內部使用了基於epoll的多路復用。

  • 對Redis來說,主要的效能瓶頸是記憶體或網路頻寬,而非CPU。

但Redis在4.0以及之後的版本中引入了惰性刪除(也叫非同步刪除),意思是我們可以使用非同步的方式對Redis中的資料進行刪除操作,例如:

  • unlink key:和del key類似,刪除指定的key,若key不存在則key被跳過。但是del會產生阻塞,而unlink指令會在另一個執行緒中回收內存,即它是非阻塞的【http://www.redis.cn/commands/unlink.html】;

  • flushdb async:刪除目前資料庫的所有資料【http://www.redis.cn/commands/flushdb.html】;

  • flushall async:刪除所有資料庫中的數據【http://www.redis.cn/commands/flushall.html】。

這樣處理的好處是不會使Redis的主執行緒卡頓,會把這些操作交給後台執行緒來執行。

【通常情況下使用del指令可以很快的刪除數據,但是當被刪除的key是一個非常大的物件時,例如:刪除的時包含成千上萬個元素的hash集合時,那麼del指令就會造成Redis主執行緒卡頓,因此使用惰性刪除可以有效避免Redis卡頓問題。 】

考點分析:

關於Redis執行緒模型的問題(單執行緒或多執行緒)幾乎是Redis必問的問題之一,但回答好的人卻不多,大部分只能回答上來Redis是單線程的以及說出來單線程的眾多好處,但對於Redis4.0和Redis6.0中,尤其是Redis6.0中多線程的特點,能夠準確回答上來的人非常少。關於單線和多執行緒的相關知識,還有以下面試題。

1.Redis主線程既然是單線程,為什麼還這個快?

2.介紹Redis中的IO多路復用?

3.介紹Redis6.0中的多執行緒?

1.Redis為什麼這麼快?

原因有以下幾點:

a.基於記憶體運算:Redis的所有資料都存在記憶體中,因此所有的運算都是記憶體等級的,所以它的效能比較高。

b.資料結構簡單:Redis的資料結構比較簡單,是為Redis專門設計的,而這些簡單的資料結構的查找和操作的時間複雜度都是O(1)。

c.多路復用和非阻塞IO:Redis使用IO多路復用功能來監聽多個socket連接的客戶端,這樣就可以使用一個線程來處理多個情況,從而減少線程切換帶來的開銷,同時也避免了IO阻塞操作,大大提升了Redis的效能。

d.避免上下文切換:因為是單執行緒模型,因此就避免了不必要的上下文切換和多執行緒競爭,這就省去了多執行緒切換帶來的時間和效能上的開銷,而且單線不會導致死鎖的問題發生。

官方使用的基準測試結果表明,單執行緒的Redis可以達到10W/S的吞吐量。

2.IO多路復用是什麼?

套接字的讀寫方法預設是阻塞的,例如當呼叫讀取操作read方法時,緩衝區沒有任何數據,那麼這個執行緒會卡在這裡,直到緩衝區有數據或者連線被關閉時,read方法才會返回,該執行緒才能繼續處理其他業務。

但這樣顯然就降低了程式的執行效率,而Redis使用的時非阻塞的IO,這就意味著IO的讀寫流程不再是阻塞的,讀寫方法都是瞬間完成並且返回的,也就是它會採用能讀多少就讀多少、能寫多少就寫多少的策略來執行IO操作,這顯然更符合我們對性能的追求。

但這種非阻塞的IO也面臨一個問題,那就是當我們執行讀取操作時,有可能只讀取了一部分資料;同理寫資料也是這種情況,當緩衝區滿了,而我們的數據還沒寫完,那麼生效的數據何時寫就成了一個問題。

而IO的多路復用就是解決上面的這個問題的,使用IO多路復用最簡單的方式就是使用select函數,此函數是操作系統提供給用戶程序的API接口,用於監控多個檔案描述符的可讀和可寫情況的,這樣就可以監控到檔案描述符的讀寫事件了。當監控到對應的時間之後就可以通知執行緒處理對應的業務了,這樣就保證了Redis讀寫功能的正常執行。

【不過現在的作業系統基本上已經不適用select函數了,改為呼叫epoll函數(Linux)了,macOS則是使用Kqueue(繼承與Unix),因為select函數在檔案描述子非常多的時候性能非常差。 】

3.Redis6.0中的多執行緒?

Redis單執行緒的優點非常,不但降低了Redis內部實作的負責性,也讓所有操作都可以在無鎖的情況下進行,而且不存在死鎖和執行緒切換帶來的效能以及時間上的消耗;但是其缺點也很明顯,單線程機制導致Redis的QPS(Query Per Second,每秒查詢數)很難得到有效的提高(雖然夠快了,但人們畢竟還是要有更高的追求的)。

Redis雖然在4.0版本中引入了多線程,但是此版本的多線程只能用於大數據量的非同步刪除,對於非刪除操作的意義並不是很大。

如果我們使用Redis多執行緒就可以分攤Redis同步讀寫IO的壓力,以及充分利用多核心CPU資源,並且可以有效的提升Redis的QPS。在Redis中雖然使用了IO多路復用,並且是基於非阻塞的IO進行操作的,但是IO的讀寫本身是阻塞的。例如當socket中有資料時,Redis會先將資料從內核態空間拷貝到使用者態空間,然後再進行相關操作,而這個拷貝過程是阻塞的,並且當資料量越大時拷貝所需的時間就越多,而這些操作都是基於單執行緒完成的。

因此在Redis6.0中新增了多執行緒的功能來提高IO的讀寫效能,它的主要實作思路是將主執行緒的IO讀寫任務拆分給一組獨立的執行緒去執行,這樣就可以使用多個socket的讀寫並行化了,但Redis的命令依舊是主執行緒串列執行的。

但是注意:Redis6.0是預設禁用多執行緒的,但可以透過設定檔redis.conf中的io-threads-do-reads 等於 true 來開啟。但還不夠,除此之外我們還需要設定執行緒的數量才能正確地開啟多執行緒的功能,同樣是修改Redis的配置,例如設定 io-threads 4,表示開啟4個執行緒。

【關於執行緒數的設置,官方的建議是如果為4核心CPU,那麼設定執行緒數為2或3;如果為8核心CPU,那麼設定執行緒數為6.總之執行緒數一定要小於機器的CPU核數,執行緒數並不是越大越好。 】

關於Redis的效能,Redis的作者在2019年的RedisConf大會上提到,Redis6.0引入的多執行緒IO特性對效能的提升至少是一倍以上。國人也有在阿里雲使用4個線程的Redis版本和單線程的Redis進行比較測試,發現測試結果和Redis作者說的一致,性能基本上可以提高一倍。

總結:

本文介紹了Redis在4.0之前單執行緒依然快的原因:基於記憶體操作、資料結構簡單、IO多路復用和非阻塞IO、避免了不必要的線程上下文切換。並且在Redis4.0開始支援多線程,主要體現在大數據的非同步刪除方面,例如:unlink key、flushdb async、flushall async等。而Redis6.0的多執行緒則增加了對IO讀寫的並發能力,用於更好的提升Redis的效能。

更多程式相關知識,請造訪:程式設計教學! !

以上是redis是單線程還是多線程,為什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
REDIS:對其數據庫方法進行分類REDIS:對其數據庫方法進行分類Apr 15, 2025 am 12:06 AM

Redis的數據庫方法包括內存數據庫和鍵值存儲。 1)Redis將數據存儲在內存中,讀寫速度快。 2)它使用鍵值對存儲數據,支持複雜數據結構,如列表、集合、哈希表和有序集合,適用於緩存和NoSQL數據庫。

為什麼要使用redis?利益和優勢為什麼要使用redis?利益和優勢Apr 14, 2025 am 12:07 AM

Redis是一個強大的數據庫解決方案,因為它提供了極速性能、豐富的數據結構、高可用性和擴展性、持久化能力以及廣泛的生態系統支持。 1)極速性能:Redis的數據存儲在內存中,讀寫速度極快,適合高並發和低延遲應用。 2)豐富的數據結構:支持多種數據類型,如列表、集合等,適用於多種場景。 3)高可用性和擴展性:支持主從復制和集群模式,實現高可用性和水平擴展。 4)持久化和數據安全:通過RDB和AOF兩種方式實現數據持久化,確保數據的完整性和可靠性。 5)廣泛的生態系統和社區支持:擁有龐大的生態系統和活躍社區,

了解NOSQL:Redis的關鍵特徵了解NOSQL:Redis的關鍵特徵Apr 13, 2025 am 12:17 AM

Redis的關鍵特性包括速度、靈活性和豐富的數據結構支持。 1)速度:Redis作為內存數據庫,讀寫操作幾乎瞬時,適用於緩存和會話管理。 2)靈活性:支持多種數據結構,如字符串、列表、集合等,適用於復雜數據處理。 3)數據結構支持:提供字符串、列表、集合、哈希表等,適合不同業務需求。

REDIS:確定其主要功能REDIS:確定其主要功能Apr 12, 2025 am 12:01 AM

Redis的核心功能是高性能的內存數據存儲和處理系統。 1)高速數據訪問:Redis將數據存儲在內存中,提供微秒級別的讀寫速度。 2)豐富的數據結構:支持字符串、列表、集合等,適應多種應用場景。 3)持久化:通過RDB和AOF方式將數據持久化到磁盤。 4)發布訂閱:可用於消息隊列或實時通信系統。

REDIS:流行數據結構指南REDIS:流行數據結構指南Apr 11, 2025 am 12:04 AM

Redis支持多種數據結構,具體包括:1.字符串(String),適合存儲單一值數據;2.列表(List),適用於隊列和棧;3.集合(Set),用於存儲不重複數據;4.有序集合(SortedSet),適用於排行榜和優先級隊列;5.哈希表(Hash),適合存儲對像或結構化數據。

redis計數器怎麼實現redis計數器怎麼實現Apr 10, 2025 pm 10:21 PM

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

redis命令行怎麼用redis命令行怎麼用Apr 10, 2025 pm 10:18 PM

使用 Redis 命令行工具 (redis-cli) 可通過以下步驟管理和操作 Redis:連接到服務器,指定地址和端口。使用命令名稱和參數向服務器發送命令。使用 HELP 命令查看特定命令的幫助信息。使用 QUIT 命令退出命令行工具。

redis集群模式怎麼搭建redis集群模式怎麼搭建Apr 10, 2025 pm 10:15 PM

Redis集群模式通過分片將Redis實例部署到多個服務器,提高可擴展性和可用性。搭建步驟如下:創建奇數個Redis實例,端口不同;創建3個sentinel實例,監控Redis實例並進行故障轉移;配置sentinel配置文件,添加監控Redis實例信息和故障轉移設置;配置Redis實例配置文件,啟用集群模式並指定集群信息文件路徑;創建nodes.conf文件,包含各Redis實例的信息;啟動集群,執行create命令創建集群並指定副本數量;登錄集群執行CLUSTER INFO命令驗證集群狀態;使

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.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

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

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具