天天看點

PHP單線程寫redis,為什麼redis是單線程的

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

PHP單線程寫redis,為什麼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程序上就可以了。