您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Redis選擇單線程的原因是什么”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Redis選擇單線程的原因是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
Redis2.6,支持lua腳本;
Redis3.0,支持集群;
Redis4.0,混合持久化,多線程異步刪除;
Redis5.0,核心代碼重構;
Redis6.0,多線程IO;
Redis7.0,Function、Multi-part-AOF;
1、Redis采用單線程模型方便開發和維護;
2、單線程模型也可以通過IO多路復用和非阻塞IO并發處理多客戶端請求;
3、對于Redis來說,主要的性能瓶頸是內存和網絡,而不是CPU;
Redis6.0之前,Redis從網絡IO處理到實際的讀寫命令處理,都是單線程的,只不過在數據刪除、數據持久化的時候使用的是多線程。
Redis的性能瓶頸主要是網絡IO,因此,Redis6.0開始,采用多個IO線程來處理網絡請求,提高網絡請求處理的并行度。
主線程負責建立連接,并把socket放入全局等待隊列,主線程通過輪詢的方法將socket連接分配給IO線程。
主線程一旦把socket分配給IO線程,就會進入阻塞狀態,等待IO線程完成客戶端請求,此時,采用多個IO線程并行處理。
IO線程解析完請求,主線程還是會以單線程的方式執行這些命令。
當主線程執行完請求命令后,會將結果寫入緩沖區,主線程進入阻塞狀態,等待IO線程將結果回寫到socket中,并返回給客戶端。
回寫socket完畢后,主線程清空全局隊列。
IO多路復用,一種同步的IO模型,實現一個線程監視多個文件句柄,一旦某個文件句柄就緒就能夠通知到對用的應用程序進行對應的讀寫操作,沒有文件句柄就緒時,程序就會進入阻塞狀態,釋放CPU資源。
1、IO,操作系統層面指數據在內核態和用戶態之間進行的讀寫操作;
2、多路,多個客戶端socket連接;
3、復用,復用線程;
4、IO多路復用,使用單線程就能夠同時處理多個客戶端socket連接;
客戶端socket對應的文件描述符FileDescriptor注冊進epoll,epoll會監聽哪些socket有消息,避免大量的無用操作。
此時socket采用非阻塞模式,整個過程只在調用select、poll、epoll時才會阻塞,收到客戶端消息不會阻塞,這個進程就會被充分利用起來,這種模式一般被稱為事件驅動,也就是reactor反應模式。
采用epoll的方式,最終目的是提高服務器的吞吐能力。
IO多路復用與epoll函數才是**“Redis為什么這么快?”**的直接原因。
讀到這里,這篇“Redis選擇單線程的原因是什么”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。