zoukankan      html  css  js  c++  java
  • swoole 安装和简单实用

    Swoole是:PHP语言的高性能网络通信框架,提供了PHP语言的异步多线程服务器,处理异步任务,异步TCP/UDP网络客户端,异步MySQL,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。 Swoole虽然是标准的PHP扩展,实际上与普通的扩展不同。普通的扩展只是提供一个库函数。而swoole扩展在运行后会接管PHP的控制权,进入事件循环。当IO事件发生后,swoole会自动回调指定的PHP函数。
    一:两种安装方式:
    1》编译安装:
    1>wget http://pecl.php.net/get/swoole-1.9.6.tgz 或者
        wget http://www.taikongliu.com/swoole/swoole-1.7.6-stable.tar.gz        //下载swoole    
    2>tar -zxvf swoole-1.7.6-stable.tar.gz        //解压swoole
    3>cd swoole-src-swoole-1.7.6-stable/        //进入swoole
    4>/phpstudy/server/php/bin/phpize        //生成configure
    5>./configure --with-php-config=/phpstudy/server/php/bin/php-config        //编译
    6>make && make install            //安装
    7>cd /phpstudy/server/php/lib/php/extensions/no-debug-non-zts-20121212    //查看是否安转上了swoole.so    (注意:此文件下边都是你安装的拓展)
    8>vim /phpstudy/server/php/etc/php.ini     //在php.ini添加extension=swoole.so加入到文件最后一行
    9>/phpstudy/server/nginx/sbin/nginx  -s reload    //重启nginx    
    10>查看phpinfo,这时候swoole拓展已经装上了

    2》PECL安装:
    1>pecl install swoole    //如果以上步骤一切正常的话,即表示swoole已经成功的安装了。
    2>extension=swoole.so            //成功之后,我们打开php.ini(不知道配置文件在哪的回去再把CLI看一遍),把swoole.so加入到文件最后
    3>$ php -m | grep swoole    //查看swoole是否被正确的安装

    如如果想要升级swoole:pecl upgrade swoole




    二:服务器端运行程序
    1>创建server.php
    <?php
    $serv = new swoole_server('127.0.0.1', 9501);    
    //server的创建,只需要绑定要监听的ip和端口,如果ip指定为127.0.0.1,则表示客户端只能位于本机才能连接,其他计算机无法连接。
    //端口这里指定为9501,可以通过netstat查看下该端口是否被占用。如果该端口被占用,可更改为其他端口,如9502,9503等。
    $serv->set([    //我开2个worker进程处理我们的业务
        'worker_num' => 2,
    ]);
    // 有新的客户端连接时,worker进程内会触发该回调
    $serv->on('Connect', function ($serv, $fd) {
        echo "new client connected." . PHP_EOL;
    });
    //参数$serv是我们一开始创建的swoole_server对象,
    //参数$fd是唯一标识,用于区分不同的客户端,同时该参数是1-1600万之间可以复用的整数。
    // server接收到客户端的数据后,worker进程内触发该回调
    $serv->on('Receive', function ($serv, $fd, $fromId, $data) {
        // 收到数据后发送给客户端
        $serv->send($fd, 'Server '. $data);
    });
    // 客户端断开连接或者server主动关闭连接时 worker进程内调用
    $serv->on('Close', function ($serv, $fd) {
        echo "Client close." . PHP_EOL;
    });
    // 启动server
    $serv->start();
    ?>

    2>由于swoole_server只能运行在CLI模式下,所以不要试图通过浏览器进行访问,这样是无效的,我们在命令行下面执行,注意一定要找到php的绝对路径
         /phpstudy/server/php/bin/php  server.php  (这行代码的意思是,把程序在服务器跑起来)
        注意:我们平时执行完一个指令,执行完就结束了,但是现在的情况正好相反,当前程序一直处于执行中的状态,并没有退出终端。退出状态一般为当前终端的执行权交给了终端,
        即可用在终端下进行其他操作,此时服务器的进程已经开启了。
    3>在开另一个终端,执行  telnet 127.0.0.1 9501  (模拟客户端请求)   如果没有安装telnet,可以 yum install -y telnet 安装
    4>创建客户端文件,也要在CLI下执行:client.php
    <?php
    // 创建一个同步阻塞的tcp socket
    // 第一个参数是表示socket的类型,有下面四种类型选择,这里选则tcp socket就好
    /**
     *     SWOOLE_SOCK_TCP 创建tcp socket
    SWOOLE_SOCK_TCP6 创建tcp ipv6 socket
    SWOOLE_SOCK_UDP 创建udp socket
    SWOOLE_SOCK_UDP6 创建udp ipv6 socket
     */
    // 第二个参数是同步还是异步
    /**
     *     SWOOLE_SOCK_SYNC 同步客户端
    SWOOLE_SOCK_ASYNC 异步客户端
     */
    $client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_SYNC);

    // 随后建立连接,连接失败直接退出并打印错误码
    $client->connect('127.0.0.1', 9503) || exit("connect failed. Error: {$client->errCode} ");
    // 向服务端发送数据
    $client->send("hello server.");
    // 从服务端接收数据
    $response = $client->recv();
    // 输出接受到的数据
    echo $response . PHP_EOL;
    // 关闭连接
    $client->close();
    5>/phpstudy/server/php/bin/php client.php        //执行客户端,输出Server hello server.
    6>使用task异步处理数据
      在建服务器程序 server_asy.php
     <?php
    /**
     * swoorl异步处理
     */
    $serv = new swoole_server("127.0.0.1", 9503);
    //配置task进程的数量,即配置task_worker_num这个配置项。比如我们开启一个task进程
    $serv->set([
        'task_worker_num' => 1,
    ]);
    $serv->on('Connect', function ($serv, $fd) {
        echo "new client connected." . PHP_EOL;
    });
    $serv->on('Receive', function ($serv, $fd, $fromId, $data) {
        echo "worker received data: {$data}" . PHP_EOL;

        // 投递一个任务到task进程中
        $serv->task($data);

        // 通知客户端server收到数据了
        $serv->send($fd, 'This is a message from server.');

        // 为了校验task是否是异步的,这里和task进程内都输出内容,看看谁先输出
        echo "worker continue run."  . PHP_EOL;
    });
    /**
     * $serv swoole_server
     * $taskId 投递的任务id,因为task进程是由worker进程发起,所以多worker多task下,该值可能会相同
     * $fromId 来自那个worker进程的id
     * $data 要投递的任务数据
     */
    $serv->on('Task', function ($serv, $taskId, $fromId, $data) {
        echo "task start. --- from worker id: {$fromId}." . PHP_EOL;
        for ($i=0; $i < 5; $i++) {
            sleep(1);
            echo "task runing. --- {$i}" . PHP_EOL;
        }
        echo "task end." . PHP_EOL;
    });

    $serv->on('Finish', function ($serv, $taskId, $data) {
        echo "finish received data '{$data}'" . PHP_EOL;
    });
    $serv->start();

    7>/phpstudy/server/php/bin/php server_asy.php        //执行服务器
    8>/phpstudy/server/php/bin/php client.php        //在执行客户端
    9>再把server_asy.php中的echo"task end." . PHP_EOL;  改成return "task end." . PHP_EOL;,执行
       /phpstudy/server/php/bin/php server_asy.php    和/phpstudy/server/php/bin/php client.php,
      这时就可以看到swoole的异步请求成功了

  • 相关阅读:
    BZOJ 4445 [Scoi2015]小凸想跑步:半平面交
    BZOJ 3931 [CQOI2015]网络吞吐量:最大流【拆点】
    BZOJ 3698 XWW的难题:有上下界的最大流
    AtCoder ARC097C Sorted and Sorted:dp
    BZOJ 1835 [ZJOI2010]base 基站选址:线段树优化dp
    BZOJ 3329 Xorequ:数位dp + 矩阵快速幂
    BZOJ 1492 [NOI2007]货币兑换Cash:斜率优化dp + cdq分治
    BZOJ 4726 [POI2017]Sabota?:树形dp
    BZOJ 1185 [HNOI2007]最小矩形覆盖:凸包 + 旋转卡壳
    存一些东西
  • 原文地址:https://www.cnblogs.com/taikongliu/p/6801950.html
Copyright © 2011-2022 走看看