目錄
swoole協程的實作原理是什麼
首頁 php框架 Swoole swoole協程的實作原理是什麼

swoole協程的實作原理是什麼

Feb 14, 2022 pm 05:42 PM
swoole

在swoole中,Swoole server接收資料在worker進程觸發onReceive回調,產生一個協程,Swoole為每個請求創建對應攜程,協程中也能創建子協程,協程在底層實現上是單線程的,因此同一時間只有一個協程在工作。

swoole協程的實作原理是什麼

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

swoole協程的實作原理是什麼

什麼是進程?

進程就是應用程式的啟動實例。獨立的檔案資源,資料資源,記憶體空間。

什麼是執行緒?

執行緒屬於進程,是程式的執行者。一個行程至少包含一個主線程,也可以有更多的子執行緒。執行緒有兩種調度策略,一是:分時調度,二是:搶佔式調度。

什麼是協程?

協程是輕量級線程,協程也是屬於線程,協程是在線程裡執行的。協程的調度是使用者手動切換的,所以又叫用戶空間線程。協程的創建、切換、掛起、銷毀全部為記憶體操作,消耗量是非常低的。協程的調度策略是:協作式調度。

Swoole 協程的原理

Swoole4 由於是單執行緒多進程的,同一時間同一個行程只會有一個協程在運作。

Swoole server 接收資料在 worker 程序觸發 onReceive 回調,產生一個攜程。 Swoole 為每個請求建立對應攜程。協程中也能創造子協程。

協程在底層實作上是單執行緒的,因此同一時間只有一個協程在工作,協程的執行是串列的。

因此多任務多協程執行時,一個協程正在執行時,其他協程會停止工作。當前協程執行阻塞 IO 操作時會掛起,底層調度器會進入事件循環。當有 IO 完成事件時,底層調度器恢復事件對應的協程的執行。 。所以協程不存在 IO 耗時,非常適合高併發 IO 場景。 (如下圖)

swoole協程的實作原理是什麼

Swoole 的協程執行流程

  • ##協程沒有IO 等待正常執行PHP 程式碼,不會產生執行流程切換

  • 協程遇到IO 等待立即將控制權切,待IO 完成後,重新將執行流切回原來協程切出的點

  • 協程並行協程依序執行,同上一個邏輯

  • 協程嵌套執行流程由外向內逐層進入,直到發生IO,然後切到外層協程,父協程不會等待子協程結束

#協程的執行順序

#先來看看基礎的範例:

go(function () {
    echo "hello go1 \n";});echo "hello main \n";go(function () {
    echo "hello go2 \n";});
登入後複製

go() 是\Co::create() 的縮寫, 用來建立一個協程, 接受callback 作為參數, callback 中的程式碼, 會在這個新建的協程中執行.

備註: \Swoole\Coroutine 可以簡寫為\Co

上面的程式碼執行結果:

root@b98940b00a9b /v/w/c/p/swoole# php co.phphello go1
hello main
hello go2
登入後複製

執行結果和我們平常寫程式碼的順序, 好像沒啥區別.實際執行過程:

  • 運行此段程式碼, 系統啟動一個新進程

  • 遇到go() , 目前行程中產生一個協程, 協程中輸出heelo go1, 協程退出

  • 程式繼續向下執行程式碼, 輸出hello main

  • #再生成一個協程, 協程中輸出heelo go2, 協程退出

運行此段程式碼, 系統啟動一個新進程. 如果不理解這句話, 你可以使用如下程式碼:

// co.php<?phpsleep(100);
登入後複製

執行並使用ps aux 查看系統中的進程:

root@b98940b00a9b /v/w/c/p/swoole# php co.php &⏎
root@b98940b00a9b /v/w/c/p/swoole# ps auxPID   USER     TIME   COMMAND
    1 root       0:00 php -a   10 root       0:00 sh   19 root       0:01 fish  749 root       0:00 php co.php  760 root       0:00 ps aux
登入後複製

我們來稍微改一改, 體驗協程的調度:

use Co;go(function () {
    Co::sleep(1); // 只新增了一行代码
    echo "hello go1 \n";});echo "hello main \n";go(function () {
    echo "hello go2 \n";});
\Co::sleep() 函数功能和 sleep() 差不多, 但是它模拟的是 IO等待(IO后面会细讲). 执行的结果如下:
root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main
hello go2
hello go1
登入後複製

怎麼不是順序執行的呢?實際執行程序:

  • 運行此段程式碼, 系統啟動一個新程序

  • 遇到go() , 在當前進程中產生一個協程

  • 協程中遇到IO阻塞(這裡是Co::sleep() 模擬出的IO等待), 協程讓出控制, 進入協程調度佇列

  • 程式繼續向下執行, 輸出hello main

  • 執行下一個協程, 輸出hello go2

  • #之前的協程準備就緒, 繼續執行, 輸出hello go1

到這裡, 已經可以看到swoole 中協程與進程的關係, 以及協程的調度, 我們再改一改剛才的程式:

go(function () {
    Co::sleep(1);
    echo "hello go1 \n";});echo "hello main \n";go(function () {
    Co::sleep(1);
    echo "hello go2 \n";});
登入後複製

我想你已經知道輸出是什麼樣子了:

root@b98940b00a9b /v/w/c/p/swoole# php co.phphello main
hello go1
hello go2
登入後複製

推薦學習:

swoole教程

以上是swoole協程的實作原理是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

swoole協程如何在laravel使用 swoole協程如何在laravel使用 Apr 09, 2024 pm 06:48 PM

Laravel 中使用 Swoole 協程可以並發處理大量請求,優點包括:同時處理:允許同時處理多個請求。高效能:基於 Linux epoll 事件機制,高效處理請求。低資源消耗:所需伺服器資源更少。易於整合:與 Laravel 框架無縫集成,使用簡單。

如何使用Swoole實現高效能的HTTP反向代理伺服器 如何使用Swoole實現高效能的HTTP反向代理伺服器 Nov 07, 2023 am 08:18 AM

如何使用Swoole實現高效能的HTTP反向代理伺服器Swoole是一款基於PHP語言的高效能、非同步、並發的網路通訊框架。它提供了一系列的網路功能,可以用來實作HTTP伺服器、WebSocket伺服器等。在本文中,我們將介紹如何使用Swoole來實作一個高效能的HTTP反向代理伺服器,並提供具體的程式碼範例。環境配置首先,我們需要在伺服器上安裝Swoole擴展

swoole框架怎麼重啟服務 swoole框架怎麼重啟服務 Apr 09, 2024 pm 06:15 PM

若要重新啟動 Swoole 服務,請依照下列步驟操作:檢查服務狀態並取得 PID。使用 "kill -15 PID" 停止服務。使用啟動服務的相同命令重新啟動服務。

swoole和workerman哪個好 swoole和workerman哪個好 Apr 09, 2024 pm 07:00 PM

Swoole 和 Workerman 都是高效能 PHP 伺服器框架。 Swoole 以其非同步處理、出色的效能和可擴展性而聞名,適用於需要處理大量並發請求和高吞吐量的專案。 Workerman 提供了非同步和同步模式的靈活性,具有直覺的 API,更適合易用性和處理較低並發量的專案。

swoole和java哪個表現好 swoole和java哪個表現好 Apr 09, 2024 pm 07:03 PM

效能比較:吞吐量:Swoole 以協程機制,吞吐量更高。延遲:Swoole 的協程上下文切換開銷更低,延遲更小。記憶體消耗:Swoole 的協程佔用記憶體較少。易用性:Swoole 提供更易於使用的並發程式設計 API。

swoole_process 怎麼讓使用者切換 swoole_process 怎麼讓使用者切換 Apr 09, 2024 pm 06:21 PM

Swoole Process 中可讓使用者切換,具體操作步驟為:建立進程;設定進程使用者;啟動進程。

Swoole實戰:如何使用協程進行並發任務處理 Swoole實戰:如何使用協程進行並發任務處理 Nov 07, 2023 pm 02:55 PM

Swoole實戰:如何使用協程進行並發任務處理引言在日常的開發中,我們常常會遇到需要同時處理多個任務的情況。傳統的處理方式是使用多執行緒或多進程來實現並發處理,但這種方式在效能和資源消耗上存在一定的問題。而PHP作為一門腳本語言,通常無法直接使用多執行緒或多進程的方式來處理任務。然而,借助於Swoole協程庫,我們可以使用協程來實現高效能的並發任務處理。本文將介

swoole協程是怎樣調度的 swoole協程是怎樣調度的 Apr 09, 2024 pm 07:06 PM

Swoole協程是一種輕量級並發函式庫,可讓開發者編寫並發程式。 Swoole協程調度機制基於協程模式和事件循環,使用協程堆疊管理協程執行,在協程讓出控制權後掛起它們。事件循環處理IO和定時器事件,協程讓出控制權時被掛起並返回事件循環。當事件發生時,Swoole從事件循環切換到掛起的協程,透過儲存和載入協程狀態完成切換。協程調度使用優先權機制,支援掛起、休眠和復原作業以靈活控制協程執行。

See all articles