资讯专栏INFORMATION COLUMN

【宇润日常疯测-007】Swoole 协程与传统 fpm 同步模式比较

henry14 / 870人阅读

摘要:初识协程执行结果协程与同步模式比较我们一直在说协程适合用于密集场景,在同样的硬件配置环境下,它会比传统的同步模式承载更多的访问量。假设一次查询为,在传统同步模式下,当前进程在这的时间里,是不能做其它操作的。同步模式,耗费左右的是。

如果说数组是 PHP 的精髓,数组玩得不6的,根本不能算是会用PHP。那协程对于 Swoole 也是同理,不理解协程去用 Swoole,那就是在瞎用。

首先,Swoole 只能运行在命令行(Cli)模式下,所以我们开发调试都是使用命令行,而不是 php-fpm/apache 等。

在 Swoole 中,我们可以使用SwooleCoroutine::create()创建协程,或者你也可以使用简写go()

初识 Swoole 协程
go(function(){
    go(function(){
        echo 0, PHP_EOL;
    });
    echo 1, PHP_EOL;
});
go(function(){
    echo 2, PHP_EOL;
});
go(function(){
    echo 3, PHP_EOL;
});

执行结果:

0
1
2
3
Swoole 协程与同步模式比较

我们一直在说 Swoole 协程适合用于 I/O 密集场景,在同样的硬件配置环境下,它会比传统的同步模式承载更多的访问量。

我们熟悉的文件读写、网络通讯请求(MySQL、Redis、Http等)都是属于 I/O 密集型场景。

假设一次 SQL 查询为 100ms,在传统同步模式下,当前进程在这 100ms 的时间里,是不能做其它操作的。如果要执行十次这个 SQL,可能需要耗费 1s 以上。

而如果用协程,虽然不同协程之间也是按顺序执行,但是在前一个等待 100ms 期间,底层会调度 CPU,去执行其它协程的操作。也就是说,可能第一个查询还没返回结果,其它几个查询就已经发送给了 MySQL 并正在执行中了。如果开启十个协程,分别执行这个 SQL,可能只需要耗费 100+ms 即可完成。

测试代码如下:

SwooleRuntime::enableCoroutine(); // 开启一键协程化

function work()
{
    $pdo = new PDO("mysql:host=127.0.0.1;dbname=db_test", "root", "root");
    $pdo->exec("select SLEEP(0.1)"); // 模拟sql需要执行 100ms 的情况
}

$time = microtime(true);
for($i = 0; $i < 10; ++$i)
{
    work();
}
echo "time: ", (microtime(true) - $time), "s", PHP_EOL;

$time = microtime(true);
for($i = 0; $i < 10; ++$i)
{
    go("work");
}
swoole_event_wait(); // 等待所有协程执行完
echo "time: ", (microtime(true) - $time), "s", PHP_EOL;

执行结果:

time: 1.0326268672943s
time: 0.10734605789185s

上面的代码可以假想为,单进程处理 10 个请求所需的时间。每个请求需要执行一次耗费 100ms 的 SQL 语句。

同步模式,耗费 1s 左右的是 fpm。可以看出,在等待 100ms 期间是不能做任何事情的。

协程模型,耗费 0.1s 左右的是 Swoole。在等待 100ms 期间会挂起当前协程,底层调度会让 CPU 去执行其它协程的操作。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/31199.html

相关文章

  • imi v1.0 正式版,专注单体应用的 PHP 协程应用开发框架

    摘要:年开发并发布框架现已停止维护。经过一年实战,年月日,一周年之际正式发布版本。宇润部分开源项目我已通过码云平台,向项目力所能及地捐款,聊表心意。所以,目前主打的还是单体应用开发。协议的开发,也是带来的一大优势。 imi 介绍 showImg(https://segmentfault.com/img/bVbuab9?w=291&h=187); imi 是基于 PHP 协程应用开发框架,它支...

    genefy 评论0 收藏0
  • 宇润日常疯测-002】Redis->eval() 到底好在哪

    摘要:今天宇润就来测试一下方法。官方说明节选从版本开始,通过内置的解释器,可以使用命令对脚本进行求值。另一方面,这也意味着,执行一个运行缓慢的脚本并不是一个好主意。将脚本缓存到服务器的操作可以通过命令进行。 平时你用 Redis 是不是经常 get()、set()一把梭?其实 Redis 中还有很多有用的数据结构,以及各种方法。今天宇润就来测试一下eval()方法。 Redis Eval 官...

    kycool 评论0 收藏0
  • 宇润日常疯测-001】使用 ; 作为代码缩进符号

    摘要:我第一次得知这种写法,是上学时候,课老师告诉我们的那么这么写除了脑残装酷炫以外,它对性能是否有影响呢通过上面的代码运行得出,使用作为缩进符,会略慢于正常写法。 ;;;;$i = 123; ;;;;echo $i, PHP_EOL; 这段代码是不是很奇葩,使用;作为代码缩进符号但是它是合法的语句,可以正常运行。并且在Java、PHP等语言中,都可以正常使用。 我第一次得知这种写法,是上学...

    bovenson 评论0 收藏0
  • 宇润日常疯测-001】使用 ; 作为代码缩进符号

    摘要:我第一次得知这种写法,是上学时候,课老师告诉我们的那么这么写除了脑残装酷炫以外,它对性能是否有影响呢通过上面的代码运行得出,使用作为缩进符,会略慢于正常写法。 ;;;;$i = 123; ;;;;echo $i, PHP_EOL; 这段代码是不是很奇葩,使用;作为代码缩进符号但是它是合法的语句,可以正常运行。并且在Java、PHP等语言中,都可以正常使用。 我第一次得知这种写法,是上学...

    monw3c 评论0 收藏0

发表评论

0条评论

henry14

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<