首页
/
每日頭條
/
圖文
/
redis支持哪些線程模型
redis支持哪些線程模型
更新时间:2024-11-18 11:04:42

相信你一定不止一次見過Redis是單線程模式,不過說實話那隻是個老版本,這個問題是一位老哥的大廠面試題,跟我分享了一下。想着自己就知道redis6.0以前一直都是單線程,到了6的版本才加入了多線程,還不是很清楚,在多方打聽并且搜索之下總結了這篇文章。

一、問題概述

Redis 6.0 之後的版本抛棄了單線程模型這一設計,原本使用單線程運行的 Redis 也開始選擇性使用多線程模型,乍一看Redis的作者這麼牛,也逃不過“真香定律”,

redis支持哪些線程模型(Redis為什麼又引入了多線程)1

仔細想想,這個問題其實可以拆分,拆分為兩個主要的問題:

(1)為什麼 Redis 一開始選擇單線程模型(單線程的好處)?

(2)為什麼 Redis 在 6.0 之後加入了多線程(在某些情況下,單線程出現了缺點,多線程可以解決)?

其實,作者并不是沒有逃脫真香定理,而是随着時間的推移,出現的問題也越來越多,原來的設計肯定就有些不合時宜,該做出改變就做出改變。OK,帶着倆問題,我們就來好好地分析一下。

二、為什麼Redis一開始使用單線程

不管是單線程或者是多線程都是為了提升Redis的開發效率,因為Redis是一個基于内存的數據庫,還要處理大量的外部的網絡請求,這就不可避免的要進行多次IO。好在Redis使用了很多優秀的機制來保證了它的高效率。那麼為什麼Redis要設計成單線程模式的呢?可以總結如下:

(1)IO多路複用

我們來看一下Redis頂層設計。

redis支持哪些線程模型(Redis為什麼又引入了多線程)2

FD是一個文件描述符,意思是表示當前文件處于可讀、可寫還是異常狀态。使用 I/O 多路複用機制同時監聽多個文件描述符的可讀和可寫狀态。你可以理解為具有了多線程的特點。

一旦受到網絡請求就會在内存中快速處理,由于絕大多數的操作都是純内存的,所以處理的速度會非常地快。也就是說在單線程模式下,即使連接的網絡處理很多,因為有IO多路複用,依然可以在高速的内存處理中得到忽略。

(2)可維護性高

多線程模型雖然在某些方面表現優異,但是它卻引入了程序執行順序的不确定性,帶來了并發讀寫的一系列問題。單線程模式下,可以方便地進行調試和測試。

(3)基于内存,單線程狀态下效率依然高

多線程能夠充分利用CPU的資源,但對于Redis來說,由于基于内存速度那是相當的高,能達到在一秒内處理10萬個用戶請求,如果一秒十萬還不能滿足,那我們就可以使用Redis分片的技術來交給不同的Redis服務器。這樣的做飯避免了在同一個 Redis 服務中引入大量的多線程操作。

而且基于内存,除非是要進行AOF備份,否則基本上不會涉及任何的 I/O 操作。這些數據的讀寫由于隻發生在内存中,所以處理速度是非常快的;用多線程模型處理全部的外部請求可能不是一個好的方案。

現在我們知道了基本上可以總結成兩句話,基于内存而且使用多路複用技術,單線程速度很快,又保證了多線程的特點。因為沒有必要使用多線程。

三、為什麼引入多線程?

剛剛說了一堆使用單線程的好處,現在話鋒一轉,又要說為什麼要引入多線程,别不适應。引入多線程說明Redis在有些方面,單線程已經不具有優勢了。

因為讀寫網絡的read/write系統調用在Redis執行期間占用了大部分CPU時間,如果把網絡讀寫做成多線程的方式對性能會有很大提升。

Redis 的多線程部分隻是用來處理網絡數據的讀寫和協議解析,執行命令仍然是單線程。之所以這麼設計是不想 Redis 因為多線程而變得複雜,需要去控制 key、lua、事務,LPUSH/LPOP 等等的并發問題。

Redis 在最新的幾個版本中加入了一些可以被其他線程異步處理的删除操作,也就是我們在上面提到的 UNLINK、FLUSHALL ASYNC 和 FLUSHDB ASYNC,我們為什麼會需要這些删除操作,而它們為什麼需要通過多線程的方式異步處理?

我們知道Redis可以使用del命令删除一個元素,如果這個元素非常大,可能占據了幾十兆或者是幾百兆,那麼在短時間内是不能完成的,這樣一來就需要多線程的異步支持。

redis支持哪些線程模型(Redis為什麼又引入了多線程)3

現在删除工作可以在後台進行。

四、總結

Redis 選擇使用單線程模型處理客戶端的請求主要還是因為 CPU 不是 Redis 服務器的瓶頸,所以使用多線程模型帶來的性能提升并不能抵消它帶來的開發成本和維護成本,系統的性能瓶頸也主要在網絡 I/O 操作上;而 Redis 引入多線程操作也是出于性能上的考慮,對于一些大鍵值對的删除操作,通過多線程非阻塞地釋放内存空間也能減少對 Redis 主線程阻塞的時間,提高執行的效率。

一句話講完:之前用單線程是因為基于内存速度快,而且多路複用有多路複用的作用,也就是足夠了,現在引入是因為在某些操作要優化,比如删除操作,因此引入了多線程。

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
王一博無名路演回答問題(無名路演有趣王一博斥黑粉)
王一博無名路演回答問題(無名路演有趣王一博斥黑粉)
  春節檔大戰還在繼續,由程耳執導梁朝偉王一博周迅主演的《無名》正在有條不紊地到指定城市的某個影院進行路演宣傳,正如一開始計劃的那樣。      《無名》講述的是上世紀二十年代奮鬥在上海的中共特科在隐蔽戰線裡與各方勢力殊死較量,以緻敬走向勝利過程中不可或缺的黨的秘密戰線上的那些無名英雄。   無名所選的路演城市也是當年被日軍轟炸過的,甚至路演順序與轟炸順序一...
2024-11-18
星際争霸十大最惡心戰術(這些單位雖然其貌不揚)
星際争霸十大最惡心戰術(這些單位雖然其貌不揚)
  星際争霸2現今已經開放到了虛空之遺資料片,随着許多版本的更新玩家們的戰術體系和兵種的搭配也是不斷地更新,玩家們對于這款遊戲的理解也是一直在加深,星際二初期人族從古老的“真善美”亂七八糟一波流到後續的各種戰術,包括玩家們經常吐槽的神族“祖傳4BG”和各種花式一波,以及蟲族的“龍狗毒爆”這些古老的戰術一直更新到現今的各種神奇的搭配都在向玩家訴說遊戲和玩家的進...
2024-11-18
曳引電梯家用井道尺寸(曳引家用電梯如何選擇)
曳引電梯家用井道尺寸(曳引家用電梯如何選擇)
  目前市面上主流的兩種家用電梯:曳引電梯和螺杆電梯。曳引電梯工作原理是通過永磁同步主機來帶動鋼絲繩或者鋼帶牽引實現轎廂上下移動,也是目前家用電梯比較常見的一種電梯類型。而曳引電梯又随着技術發展,分為了曳引鋼絲繩電梯和曳引鋼帶電梯兩大類。這兩類曳引家用電梯哪種更适合家庭使用,兩者又有啥區别呢?      傳統鋼絲繩技術成熟,用途廣泛,但是随着使用時間增加,鋼...
2024-11-18
漫威鋼鐵俠淚目瞬間(漫威最燒錢的片段)
漫威鋼鐵俠淚目瞬間(漫威最燒錢的片段)
  喜歡漫威電影的小夥伴大家好,我是皮影匠!漫威電影之所以如此成功,除了精彩故事的設定以外,還有逼真的特效。衆所周知特效越多投資越高,就是因為漫威舍得花錢,才會帶來這麼多精彩的作品。那麼你知道在《複聯4》中哪些片段最燒錢嗎?         首先就是複仇者為了尋找寶石,準備穿越回到過去時的片段。除了演員是真實的以外,包括複仇者穿戴的戰甲全部都是特效合成的。根...
2024-11-18
cfpl ag 陣容(CFPL青訓選手哪家強)
cfpl ag 陣容(CFPL青訓選手哪家強)
  CFPL S16常規賽已經進行到了第六輪,可謂緊張激烈,精彩紛呈。本屆聯賽最大的特色,就是引入了很多新人,給觀衆帶來了耳目一新的感覺。除了一些替補選手外,大量青訓隊員的上陣成為賽場上一道靓麗的風景線。但說一千道一萬,歸根結底,無論隊伍的陣容怎樣變化,能夠獲勝才是最關鍵的。下面我們就來讨論一個有趣的話題,分析下這批新人中,究竟哪支戰隊的比較厲害。     ...
2024-11-18
Copyright 2023-2024 - www.tftnews.com All Rights Reserved