首頁 >常見問題 >redis查詢為什麼速度快

redis查詢為什麼速度快

(*-*)浩
(*-*)浩原創
2019-05-24 16:50:039509瀏覽

redis查詢速度快的方法:1、redis查詢完全基於記憶體;2、redis中的資料結構簡單;3、redis採用單執行緒;4、redis使用多路I/O多工模型; 5.redis建構了VM機制。

redis查詢為什麼速度快

在程式設計師的生涯中,設定快取會想起它,控制並發會想到它,做一些壓縮儲存依舊會想到它,一直停留在知道的起點上,但沒有深入的去挖掘和總結它這麼受歡迎的原因。近期天時地利人和,整理了一下它的點點滴滴。

1、完全基於內存,絕大部分請求是純粹的內存操作,而且非常快速。資料存在記憶體中,類似HashMap,HashMap的優勢就是查找和操作的時間複雜度都是O(1);

2、資料結構簡單,對資料操作也簡單,Redis中的資料結構是專門進行設計的;

3、採用單線程,避免了不必要的上下文切換和競爭條件,也不存在多進程或者多線程導致的切換而消耗CPU,不用去考慮各種鎖的問題,不存在加鎖釋放鎖定操作,沒有因為可能出現死鎖而導致的效能消耗;

4、使用多路I/O復用模型,非阻塞IO;

5.使用底層模型不同,它們之間底層實現方式以及與客戶端之間通信的應用協議不一樣,Redis直接自己構建了VM 機制,因為一般的系統調用系統函數的話,會浪費一定的時間去移動與請求;

以上幾點都比較好理解,下邊我們針對多路I/O 復用模型進行簡單的探討:

(1)多路I/ O 復用模型

多路I/O復用模型是利用select、poll、epoll 可以同時監察多個流的I/O 事件的能力,在空閒的時候,會把當前線程阻塞掉,當有一個或多個流有I/O 事件時,就從阻塞態中喚醒,於是程式就會輪詢一遍所有的流(epoll 是只輪詢那些真正發出了事件的流),並且只依序順序的處理就緒的流,這種做法就避免了大量的無用操作。

這裡「多路」指的是多個網路連接,「重複使用」指的是複用同一個執行緒。採用多路I/O 復用技術可以讓單一執行緒高效的處理多個連線請求(盡量減少網路IO 的時間消耗),且Redis 在記憶體中操作資料的速度非常快,也就是說記憶體內的操作不會成為影響Redis效能的瓶頸,主要由以上幾點造就了Redis 具有很高的吞吐量。

以上是redis查詢為什麼速度快的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:dps是什麼意思下一篇:dps是什麼意思