当前位置:首页 > PHP教程 > php应用 > 列表

PHP Swoole 基本使用

发布:smiling 来源: PHP粉丝网  添加日期:2022-06-12 11:58:49 浏览: 评论:0 

项目中使用的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 #如果命令不存在 请在前面加上php的实际路径

./configure

make

sudo make install

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

extension=swoole.so

使用

服务端

  1. class Server{ 
  2.  
  3.     private $serv
  4.  
  5.     public function __construct() { 
  6.  
  7.         $this->serv = new swoole_server("0.0.0.0", 9501); 
  8.  
  9.         $this->serv->set(array
  10.  
  11.    
  12.  
  13.             //'worker_num' => 1,  //一般设置为服务器CPU数的1-4倍 
  14.  
  15.    
  16.  
  17.             'daemonize' => 1,  //以守护进程执行 
  18.  
  19.             'max_request' => 10000, 
  20.  
  21.             'task_worker_num' => 1,  //task进程的数量 
  22.  
  23.    
  24.  
  25.             "task_ipc_mode " => 3 ,  //使用消息队列通信,并设置为争抢模式 
  26.  
  27.             'open_length_check'    => true, 
  28.  
  29.             'dispatch_mode'        => 1, 
  30.  
  31.    
  32.  
  33.             'package_length_type'  => 'N',  //这个很关键,定位包头的 
  34.  
  35.             'package_length_offset' => 0,      //第N个字节是包长度的值 
  36.  
  37.             'package_body_offset'  => 4,      //第几个字节开始计算长度 
  38.  
  39.    
  40.  
  41.             'package_max_length'    => 2000000,  //协议最大长度 
  42.  
  43.             "log_file" => "/tmp/swoole_test.log"  //日志 
  44.  
  45.    
  46.  
  47.         )); 
  48.  
  49.    
  50.  
  51.         $this->serv->on('Receive'array($this'onReceive')); 
  52.  
  53.         $this->serv->on('Task'array($this'onTask')); 
  54.  
  55.         $this->serv->on('Finish'array($this'onFinish')); 
  56.  
  57.         $this->serv->start(); 
  58.  
  59.    
  60.  
  61.     } 
  62.  
  63.    
  64.  
  65.     public function onReceive( swoole_server $serv$fd$from_id$data ) { 
  66.  
  67.    
  68.  
  69.         //放入任务队列,开始执行 
  70.  
  71.         $task_id = $serv->task( $data ); 
  72.  
  73.    
  74.  
  75.     } 
  76.  
  77.    
  78.  
  79.     public function onTask($serv,$task_id,$from_id$data) { 
  80.  
  81.       //做一些事情 
  82.  
  83.    
  84.  
  85.     } 

客户端

  1. class Client{ 
  2.  
  3.    
  4.  
  5.     private $client$ip$port$params
  6.  
  7.    
  8.  
  9.     public function __construct($ip$port$params
  10.  
  11.     { 
  12.  
  13.    
  14.  
  15.         $this->ip = $ip
  16.  
  17.         $this->port = $port
  18.  
  19.         $this->params = $params
  20.  
  21.    
  22.  
  23.         $this->client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC); 
  24.  
  25.         $this->client->set(array
  26.  
  27.             'open_length_check'    => true, 
  28.  
  29.             'package_length_type'  => 'N'
  30.  
  31.             'package_length_offset' => 0,      //第N个字节是包长度的值 
  32.  
  33.             'package_body_offset'  => 4,      //第几个字节开始计算长度 
  34.  
  35.             'package_max_length'    => 2000000,  //协议最大长度 
  36.  
  37.    
  38.  
  39.         )); 
  40.  
  41.    
  42.  
  43.         //设置事件回调函数 
  44.  
  45.    
  46.  
  47.         $this->client->on('Connect'array($this'onConnect')); 
  48.  
  49.         $this->client->on('Receive'array($this'onReceive')); 
  50.  
  51.         $this->client->on('Close'array($this'onClose')); 
  52.  
  53.         $this->client->on('Error'array($this'onError')); 
  54.  
  55.    
  56.  
  57.         //发起网络连接 
  58.  
  59.         $this->client->connect($ip$port, 3); 
  60.  
  61.     } 
  62.  
  63.    
  64.  
  65.     public function onReceive( $cli$data ) { 
  66.  
  67.         echo "Received: " . $data . "\n"
  68.  
  69.    
  70.  
  71.     } 
  72.  
  73.    
  74.  
  75.     public function onConnect($cli) { 
  76.  
  77.    
  78.  
  79.         $data = pack('N'strlen($data)) . $data
  80.  
  81.         $cli->send($data); 
  82.  
  83.         $cli->close(); 
  84.  
  85.    
  86.  
  87.     } 
  88.  
  89.    
  90.  
  91.     public function onClose( $cli
  92.  
  93.     { 
  94.  
  95.         echo "Connection close\n"
  96.  
  97.     } 
  98.  
  99.    
  100.  
  101.     public function onError() 
  102.  
  103.     { 
  104.  
  105.         echo "Connect failed\n"
  106.  
  107.     } 
  108.  
  109.    
  110.  

注意问题

  1. 'open_length_check'    => true, 
  2.  
  3. 'package_length_type'  => 'N'
  4.  
  5. 'package_length_offset' => 0,      //第N个字节是包长度的值 
  6.  
  7. 'package_body_offset'  => 4,      //第几个字节开始计算长度 
  8.  
  9. 'package_max_length'    => 2000000,  //协长度 

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

Tags: Swoole

分享到: