在swoole中,協程可以用於高並發服務,使用協程模式服務的容錯率會大大增加,某些介面故障不會導致服務崩潰,也可以用於即時通訊聊天,可以確保通訊完全無阻塞,每個訊息均可即時的被處理。
本教學操作環境:Windows10系統、Swoole4版、DELL G3電腦
#協程的適用場景
高並發服務,如秒殺系統、高效能API介面、RPC伺服器,使用協程模式,服務的容錯率會大幅增加,某些介面出現故障時,不會導致整個服務崩潰。
爬蟲,可實現非常巨大的並發能力,即使是非常慢速的網路環境,也可以有效率地利用頻寬。
即時通訊服務,如IM聊天、遊戲伺服器、物聯網、訊息伺服器等等,可以確保訊息通訊完全無阻塞,每個訊息包都可以即時處理。
什麼是協程
協程(Coroutine)也叫用戶態線程,其透過協作而不是搶佔來進行切換。相對於進程或線程,協程所有的操作都可以在使用者態完成,創建和切換的消耗更低。協程是進程的補充,或是互補關係。
要理解是什麼是“用戶狀態的執行緒”,必然就要先理解什麼是“內核態的執行緒”。內核態的線程是由作業系統來進行調度的,在切換線程上下文時,要先保存上一個線程的上下文,然後執行下一個線程,當條件滿足時,切換回上一個線程,並恢復上下文。協程也是如此,只不過,使用者態的執行緒不是由作業系統來調度的,而是由程式設計師來調度的,就是所謂的使用者狀態的執行緒。
協程與執行緒差異
Swoole的協程在底層實作上是單執行緒的,因此同一時間只有一個協程在工作,協程的執行是串行的。這與執行緒不同,多個執行緒會被作業系統調度到多個CPU並行執行。
一個協程正在運作時,其他協程會停止運作。當前協程執行阻塞IO操作時會掛起,底層調度器會進入事件循環。當有IO完成事件時,底層調度器恢復事件對應的協程的執行。
對CPU多核心的利用,仍然依賴Swoole引擎的多進程機制。
推薦學習:swoole教學
以上是swoole協程能做什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!