為什么redis是單線程的

redis是單線程的原因:1、單線程不需要各種鎖的性能消耗;2、單線程多進程集群方案;3、采用單線程避免了不必要的上下文切換和競爭條件,也不存在多進程或者多線程導致的切換而消耗CPU。

為什么redis是單線程的

簡單分析:

(推薦教程:redis教程

Redis是基于內存的操作,CPU不是Redis的瓶頸,Redis的瓶頸最有可能是機器內存的大小或者網絡帶寬。因為單線程容易實現,并且CPU不會成為瓶頸,那么redis就順理成章地采用單線程的方案了。

詳細原因介紹:

1、不需要各種鎖的性能消耗

Redis的數據結構并不全是簡單的Key-Value,還有list,hash等復雜的結構,這些結構有可能會進行很細粒度的操作,比如在很長的列表后面添加一個元素,在hash當中添加或者刪除一個對象。這些操作可能就需要加非常多的鎖,導致的結果是同步開銷大大增加。

總之,在單線程的情況下,就不用去考慮各種鎖的問題,不存在加鎖釋放鎖操作,沒有因為可能出現死鎖而導致的性能消耗。

2、單線程多進程集群方案

單線程的威力實際上非常強大,每核心效率也非常高,多線程自然是可以比單線程有更高的性能上限,但是在今天的計算環境中,即使是單機多線程的上限也往往不能滿足需要了,需要進一步摸索的是多服務器集群化的方案,這些方案中多線程的技術照樣是用不上的。

3、CPU消耗

采用單線程,避免了不必要的上下文切換和競爭條件,也不存在多進程或者多線程導致的切換而消耗 CPU。但是如果CPU成為Redis瓶頸,或者不想讓服務器其他CUP核閑置,那怎么辦?

可以考慮多起幾個Redis進程,Redis是key-value數據庫,不是關系數據庫,數據之間沒有約束。只要客戶端分清哪些key放在哪個Redis進程上就可以了。

以上就是為什么

? 版權聲明
THE END
喜歡就支持一下吧
點贊11 分享