当前位置:首页 > CMS教程 > Thinkphp > 列表

直击Thinkphp中的Swoole

发布:smiling 来源: PHP粉丝网  添加日期:2022-06-21 09:14:17 浏览: 评论:0 

Thinkphp中使用Swoole

Swoole是一个面向生产环境的 PHP 异步网络通信引擎。使 PHP 开发人员可以编写高性能的异步并发 TCP、UDP、Unix Socket、HTTP,WebSocket 服务。

安装

首先按照Swoole官网说明安装swoole扩展,然后安装think-swoole扩展。

composer require topthink/think-swoole=2.0.*使用

使用

Swoole目前不支持Windows

使用Swoole作为HttpServer

命令行下启动服务端(需要2.0+版本think-swoole扩展)

直接在命令行下启动服务端。

php think swoole

启动完成后,会在0.0.0.0:9501启动一个HTTP Server,可以直接访问当前的应用。

swoole的参数可以在应用配置目录下的swoole.php里面配置(具体参考配置文件内容)。

如果需要使用守护进程方式运行,可以使用

php think swoole -d

或者在swoole.php文件中设置

'daemonize' =>   true

注意:由于onWorkerStart运行的时候没有HTTP_HOST,因此最好在应用配置文件中设置app_host

支持的操作包括

php think swoole [start|stop|reload|restart]

由于onWorkerStart运行的时候没有HTTP_HOST,因此最好在应用配置文件中设置app_host参数

启动后,可以使用

http://127.0.0.1:9501

访问你的应用。

如果需要配置地址和端口,可以在应用配置目录下增加

swoole.php配置文件,然后设置:

  1. <?phpreturn [ 
  2.  
  3.     'host'  => 'tp5.com'
  4.  
  5.     'port'  =>   9508,]; 

可以支持Swoole自身的配置参数设置,例如:

  1. <?phpreturn [ 
  2.  
  3.     'host'          => 'tp5.com'
  4.  
  5.     'port'          =>   9508, 
  6.  
  7.     'worker_num'    =>   4, 
  8.  
  9.     'max_request'   =>   1000,]; 

扩展中定义了onWorkerStart和onRequest事件回调方法(如果不熟悉请不要随意替换),如果你需要自定义swoole的事件回调方法,可以在配置文件中使用闭包定义。

  1. <?phpreturn [ 
  2.  
  3.     'host'          => 'tp5.com'
  4.  
  5.     'port'          =>   9508, 
  6.  
  7.     'worker_num'    =>   4, 
  8.  
  9.     'max_request'   =>   1000, 
  10.  
  11.     'WorkerStop'    =>   function($server$worker_id){ 
  12.  
  13.         // 添加你的代码 
  14.  
  15.     },]; 

或者直接在配置文件中添加

使用Swoole作为Server服务端

可以支持直接启动一个Swoole server(需要2.0.9+版本)

php think swoole:server

会在0.0.0.0:9508启动一个Websocket服务。

如果需要自定义参数,可以在config/swoole_server.php中进行配置,包括:

配置参数 描述

type 服务类型

host 监听地址

port 监听端口

mode 运行模式

socket Socket type

并且支持swoole所有的参数。

也支持使用闭包方式定义相关事件回调。

  1. return [ 
  2.  
  3.     // 扩展自身配置 
  4.  
  5.     'host'         => '0.0.0.0'// 监听地址 
  6.  
  7.     'port'         => 9501, // 监听端口 
  8.  
  9.     'type'         => 'socket'// 服务类型 支持 socket http server 
  10.  
  11.     'mode'         => SWOOLE_PROCESS, 
  12.  
  13.     'socket_type'  => SWOOLE_SOCK_TCP, 
  14.  
  15.     // 可以支持swoole的所有配置参数 
  16.  
  17.     'daemonize'    => false, 
  18.  
  19.     // 事件回调定义 
  20.  
  21.     'onOpen'       => function ($server$request) { 
  22.  
  23.         echo "server: handshake success with fd{$request->fd}\n"
  24.  
  25.     }, 
  26.  
  27.    
  28.  
  29.     'onMessage'    => function ($server$frame) { 
  30.  
  31.         echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n"
  32.  
  33.         $server->push($frame->fd, "this is server"); 
  34.  
  35.     }, 
  36.  
  37.    
  38.  
  39.     'onRequest'    => function ($request$response) { 
  40.  
  41.         $response->end("<h1>Hello Swoole. #" . rand(1000, 9999) . "</h1>"); 
  42.  
  43.     }, 
  44.  
  45.     'onClose'      => function ($ser$fd) { 
  46.  
  47.         echo "client {$fd} closed\n"
  48.  
  49.     },]; 

也可以使用自定义的服务类

  1. <?php 
  2.  
  3. namespace app\http;use think\swoole\Server;class Swoole extends Server{ 
  4.  
  5.     protected $host = '127.0.0.1'
  6.  
  7.     protected $port = 9502; 
  8.  
  9.     protected $option = [  
  10.  
  11.         'worker_num'=> 4, 
  12.  
  13.         'daemonize' => true, 
  14.  
  15.         'backlog'   => 128 
  16.  
  17.     ]; 
  18.  
  19.  
  20.     public function onReceive($server$fd$from_id$data
  21.  
  22.     { 
  23.  
  24.         $server->send($fd'Swoole: '.$data); 
  25.  
  26.     }} 

支持swoole所有的回调方法定义(回调方法必须是public类型)

serverType 属性定义为 socket或者http 则支持swoole的swoole_websocket_server和swoole_http_server

然后在swoole_server.php中增加配置参数:

  1. return [ 
  2.  
  3.     'swoole_class'  =>   'app\http\Swoole',]; 

定义该参数后,其它配置参数均不再有效。

在命令行启动服务端

php think swoole:server

支持reload|restart|stop|status 操作

php think swoole:server reload

Tags: Swoole

分享到: