背景

项目中使用的PHP,但由于长耗时的任务,前端提交以后,需要服务端异步响应。

服务器异步有多种方案,包括MQ,fsocket,Swoole等。

Swoole 使用纯 C 语言编写,提供了 PHP 语言的异步多线程服务器,异步 TCP/UDP 网络客户端,异步 MySQL,异步 Redis,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。 Swoole内置了Http/WebSocket服务器端/客户端、Http2.0服务器端。

最重要的是,完美支持PHP语言。于是使用Swoole搭建了一个异步服务器,提供异步响应,推送,定时任务等一系列工作。

安装

Swoole是C语言编写,采用编译安装的方式。

安装依赖项有:

php-5.3.10 或更高版本
gcc-4.4 或更高版本
make
autoconf
pcre (centos系统可以执行命令:yum install pcre-devel)

安装方式:

phpize
./configure
make
sudo make install

编译完成以后,需要在php.ini中添加扩展

extension=swoole.so

使用

服务端

class Server
{private $serv;public function __construct() {$this->serv = new swoole_server("0.0.0.0", 9501);$this->serv->set(array(//'worker_num' => 1,   //一般设置为服务器CPU数的1-4倍'daemonize' => 1,  //以守护进程执行'max_request' => 10000,'task_worker_num' => 1,  //task进程的数量"task_ipc_mode " => 3 ,  //使用消息队列通信,并设置为争抢模式'open_length_check'     => true,'dispatch_mode'         => 1,'package_length_type'   => 'N',  //这个很关键,定位包头的'package_length_offset' => 0,       //第N个字节是包长度的值'package_body_offset'   => 4,       //第几个字节开始计算长度'package_max_length'    => 2000000,  //协议最大长度"log_file" => "/tmp/swoole_test.log"   //日志));$this->serv->on('Receive', array($this, 'onReceive'));$this->serv->on('Task', array($this, 'onTask'));$this->serv->on('Finish', array($this, 'onFinish'));$this->serv->start();}public function onReceive( swoole_server $serv, $fd, $from_id, $data ) {//放入任务队列,开始执行$task_id = $serv->task( $data );}public function onTask($serv,$task_id,$from_id, $data) {//做一些事情}

客户端

class Client
{private $client, $ip, $port, $params;public function __construct($ip, $port, $params){$this->ip = $ip;$this->port = $port;$this->params = $params;$this->client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC);$this->client->set(array('open_length_check'     => true,'package_length_type'   => 'N','package_length_offset' => 0,       //第N个字节是包长度的值'package_body_offset'   => 4,       //第几个字节开始计算长度'package_max_length'    => 2000000,  //协议最大长度));//设置事件回调函数$this->client->on('Connect', array($this, 'onConnect'));$this->client->on('Receive', array($this, 'onReceive'));$this->client->on('Close', array($this, 'onClose'));$this->client->on('Error', array($this, 'onError'));//发起网络连接$this->client->connect($ip, $port, 3);}public function onReceive( $cli, $data ) {echo "Received: " . $data . "\n";}public function onConnect($cli) {$data = pack('N', strlen($data)) . $data;$cli->send($data);$cli->close();}public function onClose( $cli){echo "Connection close\n";}public function onError(){echo "Connect failed\n";}
}

注意问题

'open_length_check'     => true,
'package_length_type'   => 'N',
'package_length_offset' => 0,       //第N个字节是包长度的值
'package_body_offset'   => 4,       //第几个字节开始计算长度
'package_max_length'    => 2000000,  //协长度

这几个是定义帧定界的,因为Swoole的客户端和服务器端通信是TCP连接的,因此得给帧定界符,有多种帧定界方式,具体参考Swoole官方文档。这里其中是用头额外加长度的方式。

Swoole的基本使用相关推荐

  1. Swoole入门介绍

    Swoole虽然是标准的PHP扩展,实际上与普通的扩展不同.普通的扩展只是提供一个库函数.而swoole扩展在运行后会接管PHP的控制权,进入事件循环.当IO事件发生后,swoole会自动回调指定的P ...

  2. php yar swoole 比较,syar:Swoole 实现的 Yar 服务

    为何用swoole来实现 Yar server 历史代码使用了yar, 不想过多修改客户端代码 提升Yar服务端执行效率 学习swoole, yar(在此感谢laruence,rango及swoole ...

  3. swoole实现数据库连接池

    2019独角兽企业重金招聘Python工程师标准>>> 原生 PHP CURD 让我们来回顾一下PHP中数据库的使用 <?php # curd.php$id = 1;$dbh ...

  4. Swoft 2 Beta 发布,基于 Swoole 的云原生协程框架

    Swoft 是首个基于 Swoole 原生协程的框架,从开发到发布据今已有2年多. 1.x 发布以来,已有大量的开发人员和企业使用,得到了大家的认可.从去年11月份开始,将近半年的时间从零开始,底层吸 ...

  5. mysql for循环_基于Swoole扩展开发异步高性能的MySQL代理服务器

    MySQL数据库对每个客户端连接都会分配一个线程,所以连接非常宝贵.开发一个异步的MySQL代理服务器,PHP应用服务器可以长连接到这台Server,既减轻MYSQL的连接压力,又使PHP保持长连接减 ...

  6. php7 swoole 扩展,PHP7.2加入swoole扩展

    首先找到phpize的位置,一般在安装目录的bin目录中 在swoole文件夹中执行phpize season@ubuntu:~/Downloads/swoole$ /usr/local/php/bi ...

  7. php swoole编译,编译安装swoole1.7.9,PHP版本5.6.5

    1.下载swoole wget https://codeload.github.com/swoole/swoole-src/tar.gz/swoole-1.7.9-stable 2.解压​ tar - ...

  8. macos big sur安装php扩展_用PHP构建基于swoole扩展的socket服务(附PHP扩展安装步骤)...

    最近公司的一项目中,需要用PHP搭建一个socket服务. 本来PHP是不适合做服务的,因为和第三方合作,需要采用高效而稳定的TCP协议进行数据通信.经过多次尝试,最终选择了开源的PHP扩展:swoo ...

  9. tp5 异步处理_tp5.1 swoole 实现异步处理

    客户端请求: namespace app\index\controller; class Index { public function index() { $client = new \swoole ...

  10. 前端调用mysql异步_PHP 使用 Swoole – TaskWorker 实现异步操作 Mysql

    在一般的 Server 程序中都会有一些耗时的任务,比如:发送邮件.聊天服务器发送广播等.如果我们采用同步阻塞的防水去执行这些任务,那么这肯定会非常的慢. Swoole 的 TaskWorker 进程 ...

最新文章

  1. 教育部:建设100+AI特色专业,500万AI人才缺口要补上!
  2. STM8中GPIO的12种模式
  3. 《不只是美:信息图表设计原理与经典案例》—— 2.5 功能限制形式
  4. ccna学习指南笔记9
  5. pythonnamedtuple定义类型_详解Python中namedtuple的使用
  6. 帮助文档的数据库结构
  7. thinkphp模版常量替换机制
  8. BestCoder Round #91 1001 Lotus and Characters
  9. lr中winsock协议的脚本(转载51testing)
  10. win10硬盘修复工具使用教程
  11. CUDA: OpenCV requires enabled ‘cudev‘ module from ‘opencv_contrib
  12. birt插件 web_Maven方式集成BIRT 4.6 Webviewer
  13. 数字图像matlab心得,Matlab数字图像处理的学习建议
  14. Python格式化输出--%s,%d,%f
  15. txt形式进行传输WebShell图文演示!
  16. 大朗机器人餐厅在哪里_获得海内外一致好评,送餐机器人为中国餐饮打开新世界...
  17. TreeList(一)
  18. Python 3.65 安装geopandas
  19. matlab:xlsread
  20. 7z文件格式及其源码的分析(六)-完结篇

热门文章

  1. 阿里云服务器升级node版本
  2. 有没有一个桌面日历点击某天就可以直接填写便签内容
  3. 子域和域之间共享cookie
  4. PrintDocument DrawString C# 换行问题
  5. 七夕到了,程序员怎么过七夕
  6. 台电 X98 Plus WiFi版 平板 安装 archlinux
  7. 使用百度大脑EasyDL创建吸烟监控模型
  8. 码云即将支持 Git v2 Protocol
  9. 明文攻击之猪圈密码、希尔密码..
  10. 企业安全生产的保护伞,工业设备智能维保平台