easyswoole - 基于swoole扩展实现的一款高性能php框架

協程

協程不是進程或線程,其執行過程更類似于子例程,或者說是不帶返回值的函數調用。

一個程序可以包含多個協程,可以對比于一個進程可以包含多個線程,下面我們來比較協程和線程。因為多個線程相對獨立,有自己的上下文,切換受系統控制;

而協程也相對獨立,有自己的上下文,但是其切換由自己控制,當前協程切換到其他協程可以由當前協程來控制。

協程

協程執行順序

原生 php 代碼:

<?php
function task1()
{
    for ($i = 0; $i <= 300; $i++) {
        // 寫入文件,大概要 3000 微秒
        usleep(3000);
        echo "寫入文件{$i}\n";
    }
}

function task2()
{
    for ($i = 0; $i <= 500; $i++) {
        // 發送郵件給 500 名會員,大概 3000 微秒
        usleep(3000);
        echo "發送郵件{$i}\n";
    }
}

function task3()
{
    for ($i = 0; $i <= 100; $i++) {
        // 模擬插入 100 條數據,大概 3000 微秒
        usleep(3000);
        echo "插入數據{$i}\n";
    }
}

task1();
task2();
task3();

在這個代碼中,我們主要做了 3 件事:寫入文件、發送郵件、及插入數據。

再看下面這段代碼:

<?php
function task1($i)
{
    // 使用 $i 標識 寫入文件,,大概要3000微秒
    if ($i > 300) {
        return false;// 超過 300 不用寫了
    }
    echo "寫入文件{$i}\n";
    usleep(3000);
    return true;
}

function task2($i)
{
    // 使用 $i 標識 發送郵件,大概要 3000 微秒
    if ($i > 500) {
        return false;// 超過 500 不用發送了
    }
    echo "發送郵件{$i}\n";
    usleep(3000);
    return true;
}

function task3($i)
{
    // 使用 $i 標識 插入數據,大概要 3000 微秒
    if ($i > 100) {
        return false;// 超過 100 不用插入
    }
    echo "插入數據{$i}\n";
    usleep(3000);
    return true;
}

$i = 0;
$task1Result = true;
$task2Result = true;
$task3Result = true;
while (true) {
    $task1Result && $task1Result = task1($i);
    $task2Result && $task2Result = task2($i);
    $task3Result && $task3Result = task3($i);
    if ($task1Result === false && $task2Result === false && $task3Result === false) {
        break;// 全部任務完成,退出循環
    }
    $i++;
}

這段代碼也是做了 3 件事,寫入文件、發送郵件和插入數據。但是和上面的不同的是,這段代碼將這 3 件事交叉執行,每個任務執行完一次之后,切換到另一個任務,如此循環。類似于這樣的執行順序,就是協程。

協程是指一種用代碼實現任務交叉執行的邏輯,協程可以使得代碼 1 中的 3 個函數交叉運行,在實現了協程的框架中,我們不需要通過代碼 2 的方法實現任務交叉執行。直接可讓代碼 1 中的 while(1),執行一次后切換。

協程的實現

php 中,實現協程主要使用 2 種方式:

  • yield 生成器實現
  • swoole 擴展實現

swoole 實現協程代碼:

<?php
function task1()
{
    for ($i = 0; $i <= 300; $i++) {
        // 寫入文件,大概要 3000 微秒
        usleep(3000);
        echo "寫入文件{$i}\n";
        Co::sleep(0.001);// 掛起當前協程,0.001 秒后恢復 // 相當于切換協程
    }
}

function task2()
{
    for ($i = 0; $i <= 500; $i++) {
        // 發送郵件給 500 名會員,大概 3000 微秒
        usleep(3000);
        echo "發送郵件{$i}\n";
        Co::sleep(0.001);// 掛起當前協程,0.001 秒后恢復 // 相當于切換協程
    }
}

function task3()
{
    for ($i = 0; $i <= 100; $i++) {
        // 模擬插入 100 條數據,大概 3000 微秒
        usleep(3000);
        echo "插入數據{$i}\n";
        Co::sleep(0.001);// 掛起當前協程,0.001 秒后恢復 // 相當于切換協程
    }
}

$pid1 = go('task1');// go 函數是 swoole 的開啟協程函數,用于開啟一個協程
$pid2 = go('task2');
$pid3 = go('task3');

以上代碼,即可實現切換函數。

為什么要用 sleep 掛起協程實現切換呢?因為 swoole 的協程是自動的,當協程內遇上 I/O 操作 (mysql、redis) 等時,swoole 的協程會自動切換,運行到下一個協程任務中 (切換后,I/O繼續執行),直到下一個協程任務完成或者被切換 (遇上 I/O),如此反復,直到所有協程任務完成,則任務完成。

協程與進程

由上面的 協程執行順序 中的代碼 2,我們很容易發現,協程其實只是運行在一個進程中的函數,只是這個函數會被切換到下一個執行,可以這么說:

協程只是一串運行在進程中的任務代碼,只是這些任務代碼可以交叉運行。 注意,協程并不是多任務并行,屬于多任務串行,每個進程在一個時間只執行了一個任務。

主站蜘蛛池模板: 激光切管机_等离子切管机_相贯线切管机厂家|服务为先-山东美峰智能设备有限公司 | 苏州ERP定制|苏州CRM|苏州OA|苏州BPM|进销存管理系统-苏州中尚信息科技有限公司 | 潍坊劲昊磁电科技有限公司-电磁除铁器,永磁除铁器,管道式除铁器,金属探测仪,磁滚筒,输送设备,给料设备,破碎设备 | 生物安全柜检测,GMP设备确认,仪器性能确认,洁净厂房检测,仓储温湿度检测-上海熙迈 | 数据采集卡_北京科尔特兴业测控技术研究所 | 联系我们-99贵宾在线客服开户电话17508888884(99厅) | 斩天手游网_高质量手机游戏下载中心 | 中超直播_中超直播在线直播_中超直播免费直播视频直播-24直播网 中标通国际认证(深圳)有限公司-知识产权管理体系认证-湖北知识产权贯标 | 领先的一站式_专利申请代理知识产权服务平台_乐知网 | 衢州装饰公司_衢州装修公司_衢州创美装饰工程有限公司 - Powered by www.qzcmzs.com | 在线式风速仪_直读式流速仪-北京亚欧德鹏科技有限公司 | 气动隔膜调节阀,气动比例调节隔膜阀|川熙流体设备百科 | 铸铁平台,三维柔性焊接平台,划线平台,大理石平台,检验平板,花岗石平台_泊头市恒量机械设备有限公司 | 自动烘干线,工业烘箱生产厂家-湖南耐美特智能装备有限公司官方网站 | 上海物流公司_上海冷链运输_空运_电商仓储配送电话-迈泽物流 | 辣椒烘干机-百信机械提供大中小型辣椒烘干机房设备视频图片厂家价格多少钱 | 黄山市惠康膳食管理服务有限公司 - 官网首页 | 碎料机_拌料机_吸料机_温控箱_烤料斗_模温机_东莞索亿塑料破碎机厂家 | 上海鳞片胶泥-环氧胶泥价格-鳞片涂料批发-乙烯基树脂-环氧结构胶-上海富晨 | 温州网络公司_网站建设_网络营销策划_阿里淘宝店铺服务-温州聚欣网络科技有限公司 | 深圳钢成培训专业从事,五轴培训,车铣复合培训,数控车床,CNC数控编程,模具编程 ,钣金机械与模具设计,powermill,mastercam,solidworks,ug,hypermill培训 | 上海塑料链条生产厂家-塑料网带批发-柔性齿形链价格-上海瀚幽传动机械有限公司 | 直饮水设备-纯水设备-软化水设备 - 亿家清泉水处理设备厂家 | 上海鑫迪机械有限公司 上海科蜀智能机械有限公司 | 实验室冷水机-冷却循环水系统-深圳市达沃西制冷设备厂 | 商标转让_商标买卖交易平台_商标转让注册网站-世标网 | 汽车检具标准件_汽车检具配件_昆山宏易腾达模具五金有限公司 | 潍坊亿宏重工机械有限公司,破碎机,高性能立磨机,颚式破碎机,锤式破碎机反击式破碎机,重锤式破碎机,高性能反击式破碎机,圆锥式破碎机,给料机系列,链板给料机系列,简易给料机系列,振动给料机 | 开关柜无线测温_电缆接头测温系统_六氟化硫sf6气体泄漏报警监测_卫星同步时钟-山东正瑞电子有限公司 | 液体灌装机-酱料灌装机-全自动灌装机-旋盖机-铝箔封口机-贴标机厂家-迈特威自动化设备(天津)有限公司" | 莫非传媒官网-江西知名的网络营销推广服务平台南昌网络公司,专业网络公关,品牌危机处理,网站SEO优化,微信朋友圈广告,网站建设,南昌莫非文化传媒有限公司 | 体育馆木地板厂家_篮球木地板价格_舞台木地板品牌-欧氏地板 | 江门市振达机械制造有限公司_散货输送系统_全密封带式输送机 | 砂金设备-淘金机械-金矿选矿设备厂家-青州冠诚重工机械有限公司 砂浆生产线_干混砂浆设备_干混砂浆生产线-苏州一工机械有限公司 | 自走式缠绕机_上海德目包装设备厂家_在线式缠绕机_缠绕膜打包机 自装卸(挂桶)车|钩臂垃圾车|压缩垃圾车|密封自卸车|环卫垃圾车|餐厨车泔水车湖北程力专用车厂家 | 中婴网,推动母婴产业健康·可持续发展,婴童网络专业传媒,母婴网,360孕婴童网,婴童品牌,婴儿用品品牌,婴儿用品加盟店,母婴用品加盟店 | 新乡市大成数控机械有限公司| 线宽测试仪丨光调制分析仪丨调制器 卓越光子-专注于光电解决方案 | 山西档案架,智能档案密集架,手摇密集架,山西密集架厂家批发/报价 | 泡沫混凝土垫层填充厂家,发泡混凝土垫层填充,轻质混凝土垫层填充厂家,深圳市鸿奥建材发展有限公司 | 汽车轴承|圆锥滚子轴承|轴承生产厂家|赛襄轴承 |