亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Redis選擇單線程的原因是什么

發布時間:2023-03-21 11:20:39 來源:億速云 閱讀:75 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Redis選擇單線程的原因是什么”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Redis選擇單線程的原因是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

一、Redis版本迭代

Redis選擇單線程的原因是什么

Redis2.6,支持lua腳本;

Redis3.0,支持集群;

Redis4.0,混合持久化,多線程異步刪除;

Redis5.0,核心代碼重構;

Redis6.0,多線程IO;

Redis7.0,Function、Multi-part-AOF;

二、Redis4.0之前為什么一直采用單線程?

1、Redis采用單線程模型方便開發和維護;

2、單線程模型也可以通過IO多路復用和非阻塞IO并發處理多客戶端請求;

3、對于Redis來說,主要的性能瓶頸是內存和網絡,而不是CPU;

三、Redis6.0引入多線程

Redis6.0之前,Redis從網絡IO處理到實際的讀寫命令處理,都是單線程的,只不過在數據刪除、數據持久化的時候使用的是多線程。

Redis的性能瓶頸主要是網絡IO,因此,Redis6.0開始,采用多個IO線程來處理網絡請求,提高網絡請求處理的并行度。

四、Redis主線程和IO線程是如何完成請求的?

Redis選擇單線程的原因是什么

1、服務端和客戶端建立socket連接

主線程負責建立連接,并把socket放入全局等待隊列,主線程通過輪詢的方法將socket連接分配給IO線程。

2、IO線程讀取并解析請求

主線程一旦把socket分配給IO線程,就會進入阻塞狀態,等待IO線程完成客戶端請求,此時,采用多個IO線程并行處理。

3、主線程執行請求命令

IO線程解析完請求,主線程還是會以單線程的方式執行這些命令。

4、IO線程會寫回socket和主線程清空全局隊列

當主線程執行完請求命令后,會將結果寫入緩沖區,主線程進入阻塞狀態,等待IO線程將結果回寫到socket中,并返回給客戶端。

回寫socket完畢后,主線程清空全局隊列。

五、IO多路復用是什么?

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選擇單線程的原因是什么”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南江县| 葫芦岛市| 哈尔滨市| 鄄城县| 德格县| 明溪县| 仙桃市| 泰来县| 元朗区| 宝鸡市| 平度市| 鹿泉市| 雅江县| 山西省| 德阳市| 浮山县| 禹城市| 吴旗县| 大城县| 金乡县| 曲水县| 乌什县| 都安| 新民市| 姜堰市| 苍梧县| 丽江市| 平塘县| 罗甸县| 鄂州市| 田东县| 安吉县| 闸北区| 迭部县| 金塔县| 洛宁县| 山东| 三都| 武汉市| 宁武县| 阿瓦提县|