redis单线程架构
Redis單進程單線程架構
?? ?1、單線程模型
? ??? ?Redis客戶端對服務端的每次調用都經歷了發送命令,執行命令,返回結果三個過程。
? ? ?? ?其中執行命令階段,由于Redis是單線程來處理命令的,所有每一條到達服務端的命令不會立刻執行,所有的命令都會進入一個隊列中,然后逐個被執行。
? ? ?? ?并且多個客戶端發送的命令的執行順序是不確定的。但是可以確定的是不會有兩條命令被同時執行,不會產生并發問題,這就是Redis的單線程基本模型。
?? ?2、單線程模型每秒萬級別處理能力的原因
?? ?(1)純內存訪問。數據存放在內存中,內存的響應時間大約是100納秒,這是Redis每秒萬億級別訪問的重要基礎。
?? ?(2)非阻塞I/O,Redis采用epoll做為I/O多路復用技術的實現,再加上Redis自身的事件處理模型將epoll中的連接,讀寫,關閉都轉換為了時間,不在I/O上浪費過多的時間。
?? ?(3)單線程避免了線程切換和競態產生的消耗。
?? ?(4)Redis采用單線程模型,每條命令執行如果占用大量時間,會造成其他線程阻塞,對于Redis這種高性能服務是致命的,所以Redis是面向高速執行的數據庫。
單進程單線程好處:
?? ?代碼更清晰,處理邏輯更簡單
?? ?不用去考慮各種鎖的問題,不存在加鎖釋放鎖操作,沒有因為可能出現死鎖而導致的性能消耗
?? ?不存在多進程或者多線程導致的切換而消耗CPU
單進程單線程弊端
?? ?無法發揮多核CPU性能,不過可以通過在單機開多個Redis實例來完善;
其他一些優秀的開源軟件采用的模型
?? ?多進程單線程模型:Nginx
?? ?單進程多線程模型:Memcached
總結
以上是生活随笔為你收集整理的redis单线程架构的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: git去掉某个commit的措施
- 下一篇: linux命令nohup