日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

單機輕松10萬QPS的redis竟然是單線程的?!很多人都認為高并發就意味著多核心多進程,但這兩者之間并沒有特別大的聯系。除了Redis之外,像Node.JS也是如此,那么為什么Redis能夠如此之快呢?

 

單線程的Redis為什么輕松達到數萬并發,記住這兩點

 

 

首先,我們得了解下常見的網絡模型,當客戶端連接到服務器的時候,服務器有下面幾個步驟:

  • 從Socket中讀取客戶端傳輸過來的數據
  • 進行服務器相關邏輯的處理
  • 把數據寫回到連接客戶端的Socket當中

這就是我們常見的同步IO,這種IO方式存在什么問題呢?就是當從Socket中讀取數據的時候,數據很有可能還沒有從客戶端傳到服務端,那么這個線程就一直會在那邊等,直到讀到足夠多的數據從客戶端傳上來,這個效率自然就高不上去。就好比一個人去釣魚,一次只放一條魚竿,然后守在旁邊一直盯著這條魚竿,直到魚兒上鉤再拉起來,中間做不了其他事情。

要提高機器的運行效率,我們有兩件事情要做,一個是使用非阻塞IO,另一個是進行多路復用。

首先,什么是非阻塞IO呢?原本,我們從Socket讀取數據的時候,約定讀4kb,如果讀取不夠,就在那里傻等,現在變成了讀取數據的時候,采用的是非阻塞的方法,如果讀取不到4kb的數據,那么有多少就返回多少,等待下一次讀取。就像剛剛釣魚中的例子,原先我們是一直盯著魚竿看,現在變成了我們看一下魚竿,然后就可以低頭玩手機,干其他事情。

其次是多路復用,既然我們不用死盯著一根魚竿,為什么我們不一口氣多開多幾條魚竿呢?等到魚竿有動靜了,再去看看。Redis亦是如此,在Redis中,采用到多路復用的技術,一個線程連接多個客戶端。在linux操作系統中,采用的是Epoll,一旦有Socket讀寫事件發生,Linux的內核會通知線程進行處理。

有了上述的異步IO與多路復用之后,Redis會維護一個指令隊列,把從客戶端中收到的指令放在隊列當中。隊列當中的指令會排隊執行,進行客戶端要求的各種操作。當Redis服務端完成任務之后,會將結果放入響應隊列當中,等待恰當的時候,寫給客戶端。

正因為Redis是單線程的服務,所以Redis在使用的時候,要注意不要使用O(N)級別的指令,免得系統資源被占用,從而拖慢整個系統。

其實,說Redis是個單線程的服務也不太準確,在Redis的后臺,進行定時任務處理、進行持久化的時候,是會通過其他線程進行處理的。

 

總結

Redis為什么單線程也能保持如此高的并發呢?最重要的亮點,就是異步IO與多路復用,記住了么?

分享到:
標簽:Redis
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定