Redis 為什麼使用單程序單執行緒方式也這麼快

2022-09-02 09:39:11 字數 807 閱讀 2862

redis 快的主要原因有:

完全基於記憶體;

資料結構簡單,對資料操作也簡單;

使用多路 i/o 復用模型;

第一、二點不細講,主要圍繞第三點採用多路 i/o 復用技術來展開。

多路 i/o 復用模型是利用 select、poll、epoll 可以同時監察多個流的 i/o 事件的能力,在空閒的時候,會把當前執行緒阻塞掉,當有乙個或多個流有 i/o 事件時,就從阻塞態中喚醒,於是程式就會輪詢一遍所有的流(epoll 是只輪詢那些真正發出了事件的流),並且只依次順序的處理就緒的流,這種做法就避免了大量的無用操作。這裡「多路」指的是多個網路連線,「復用」指的是復用同乙個執行緒。採用多路 i/o 復用技術可以讓單個執行緒高效的處理多個連線請求(儘量減少網路 io 的時間消耗),且 redis 在記憶體中運算元據的速度非常快(記憶體內的操作不會成為這裡的效能瓶頸),主要以上兩點造就了 redis 具有很高的吞吐量。

和 memcached 不同,redis 並沒有直接使用 libevent,而是自己完成了乙個非常輕量級的對 select、epoll、evport、kqueue 這些通用的介面的實現。在不同的系統呼叫選用適合的介面,linux 下預設是 epoll。因為 libevent 比較重,更通用,**量也就很龐大,擁有很多 redis 用不上的功能,redis 為了追求「輕巧」並且去除依賴,就選擇自己去封裝了一套。

**更清晰,處理邏輯更簡單

不用去考慮各種鎖的問題,不存在加鎖釋放鎖操作,沒有因為可能出現死鎖而導致的效能消耗

不存在多程序或者多執行緒導致的切換而消耗 cpu

無法發揮多核 cpu 效能,不過可以通過在單機開多個 redis 例項來完善;

Redis為什麼使用單程序單執行緒方式

redis採用的是基於記憶體的採用的是單程序單執行緒模型的kv資料庫,由c語言編寫。官方提供的資料是可以達到100000 的qps。這個資料不比採用單程序多執行緒的同樣基於記憶體的kv資料庫memcached差。redis快的主要原因是 完全基於記憶體 資料結構簡單,對資料操作也簡單 使用多路 i ...

Redis為什麼使用單程序單執行緒方式

redis為什麼使用單程序單執行緒方式?redis採用的是基於記憶體的採用的是單程序單執行緒模型的kv資料庫,由c語言編寫。官方提供的資料是可以達到100000 的qps。redis快的主要原因是 1.完全基於記憶體 2.資料結構簡單,對資料操作也簡單 3.使用多路 i o 復用模型 單程序單執行緒...

Redis為什麼使用單程序單執行緒方式也這麼快

redis採用的是基於記憶體的採用的是單程序單執行緒模型的kv資料庫,由c語言編寫。官方提供的資料是可以達到100000 的qps。這個資料不比採用單程序多執行緒的同樣基於記憶體的kv資料庫memcached差。redis快的主要原因是 完全基於記憶體 資料結構簡單,對資料操作也簡單 使用多路 i ...