swoole協程能做什么

swoole中,協程可以用于高并發服務,使用協程模式服務的容錯率會大大增加,某些接口出現故障也不會導致服務崩潰,也可以用于即時通訊聊天,可以確保通信完全無阻塞,每個消息均可即時的被處理。

swoole協程能做什么

本教程操作環境:Windows10系統、Swoole4版、DELL G3電腦

swoole協程能做什么

協程的適用場景

高并發服務,如秒殺系統、高性能API接口、rpc服務器,使用協程模式,服務的容錯率會大大增加,某些接口出現故障時,不會導致整個服務崩潰。

爬蟲,可實現非常巨大的并發能力,即使是非常慢速的網絡環境,也可以高效地利用帶寬。

即時通信服務,如IM聊天、游戲服務器、物聯網、消息服務器等等,可以確保消息通信完全無阻塞,每個消息包均可即時地被處理。

什么是協程

協程(Coroutine)也叫用戶態線程,其通過協作而不是搶占來進行切換。相對于進程或者線程,協程所有的操作都可以在用戶態完成,創建和切換的消耗更低。協程是進程的補充,或者是互補關系。

要理解是什么是“用戶態的線程”,必然就要先理解什么是“內核態的線程”。內核態的線程是由操作系統來進行調度的,在切換線程上下文時,要先保存上一個線程的上下文,然后執行下一個線程,當條件滿足時,切換回上一個線程,并恢復上下文。協程也是如此,只不過,用戶態的線程不是由操作系統來調度的,而是由程序員來調度的,就是所謂的用戶態的線程。

協程與線程區別

Swoole的協程在底層實現上是單線程的,因此同一時間只有一個協程在工作,協程的執行是串行的。這與線程不同,多個線程會被操作系統調度到多個CPU并行執行。

一個協程正在運行時,其他協程會停止工作。當前協程執行阻塞IO操作時會掛起,底層調度器會進入事件循環。當有IO完成事件時,底層調度器恢復事件對應的協程的執行。

對CPU多核的利用,仍然依賴于Swoole引擎的多進程機制。

推薦學習: swoole教程

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊11 分享