zoukankan      html  css  js  c++  java
  • PHP+Swoole并发编程的魅力

    PHP语言是一个短生命周期的Web编程语言,很多PHPer已经形成了fpm下编程的思维定势。实际上在Swoole出现之后,这种串行化编程的模式早已被打破。使用Swoole完全可以轻易实现更灵活的并发编程。

    场景介绍
    假设我们要做一个石头剪刀布的Web游戏,3个玩家同时提交竞猜后显示胜者。在传统串行化Web编程中,我们一般思路是这样:

    设置 form 表单,用户提交竞猜后保存到 MySQL/Redis 存储
    添加一个查看结果按钮,如果未全部完成,显示正在等待其他人提交。当3个人全部提交时,查询存储,并显示最终结果
    并发编程
    这个场景就可以使用Swoole实现并发编程,无需依赖 MySQL/Redis 存储,在内存中可以完成竞猜。

    当有用户提交竞猜时,hold 住请求,不返回结果,用户进入等待状态。当前请求和连接保持在内存中
    当3个人全部提交时,从内存中取出相关请求的内容,计算并遍历向所有请求发送响应
    编码实现

     1 <?php
     2 $server = new SwooleHttpServer('127.0.0.1', 9501, SWOOLE_BASE);
     3 $result = [];
     4 $server->on('request', function ($req, $resp) use(&$result) {
     5 $resp->header('Content-Type', 'text/html; charset=UTF-8');
     6 if ($req->server['request_method'] == 'GET') {
     7 $resp->end('
     8 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
     9 <form method="post" action="">
    10 <input type="radio" value="石头" name="result">石头
    11 <input type="radio" value="剪刀" name="result">剪刀
    12 <input type="radio" value="布" name="result">布
    13 <button type="submit">提交</button>
    14 </form>
    15 ');
    16 } else {
    17 $result[$req->get['name']] = [$req, $resp];
    18 if (count( $result) == 3) {
    19 $out = '';
    20 foreach($result as $arr) {
    21 [$_req, $_resp] = $arr;
    22 $out .= $_req->get['name'] ." : ". $_req->post['result']."<br />
    ";
    23 }
    24 foreach($result as $arr) {
    25 [$_req, $_resp] = $arr;
    26 $_resp->end($out);
    27 }
    28 $result = [];
    29 }
    30 }
    31 });
    32 $server->start();

    执行程序

    php game.php

    打开3个Chrome的Tab页。并且URL中传入name分别为A、B、C代表3个用户。

     

     

     

    在第一个、第二个提交结果时,并未返回任何结果,Chrome正在转圈等待服务器返回结果。第三个表单提交时3个Tab页同时返回结果。

    并发难题
    并发编程比串行编程更强大,也更复杂。并发编程会遇到之前串行编程所没有的新问题,如:

    数据同步问题
    上下文管理问题
    时序问题
    这需要开发者具备更严谨的工程思维能力,也需要开发者具备更深厚的编程功底。

    思维转变
    Swoole其实颠覆了以往PHP的编程模式,使得程序员的视野不再局限于一次请求的处理,不再局限于对于数据库CURD操作、接口调用。配合使用Swoole4提供的协程编程能力,就可以在内存空间内实现各种复杂的交互。

    新的编程模式,可以让PHPer轻松地去实现网络游戏、服务器系统、智能家居、物联网等项目。

  • 相关阅读:
    函数、包和错误处理
    程序流程控制
    poj 2515 Birthday Cake
    poj 2094 多项式求和。
    hdu 3625 第一类striling 数
    hdu 4372 第一类stirling数的应用/。。。好题
    poj 1845 Sumdiv
    hdu 3641 Treasure Hunting 强大的二分
    poj 3335 /poj 3130/ poj 1474 半平面交 判断核是否存在 / poj1279 半平面交 求核的面积
    hdu 2841 Visible Trees
  • 原文地址:https://www.cnblogs.com/a609251438/p/11836701.html
Copyright © 2011-2022 走看看