Directly click on Swoole in Thinkphp

coldplay.xixi
Release: 2023-04-08 19:10:02
forward
4506 people have browsed it


Directly click on Swoole in Thinkphp

Using Swoole in Thinkphp

Swoole is a PHP asynchronous network communication engine for production environments. Enables PHP developers to write high-performance asynchronous and concurrent TCP, UDP, Unix Socket, HTTP, and WebSocket services.

Installation

First install the swoole extension according to the instructions on the Swoole official website, and then install the think-swoole extension.

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

Using

Swoole currently does not support Windows

Using Swoole as HttpServer

Start the server from the command line (Requires version 2.0 think-swoole extension)
Start the server directly from the command line.

php think swoole
Copy after login

After the startup is completed, an HTTP Server will be started at 0.0.0.0:9501, which can directly access the current application.

The parameters of swoole can be configured in swoole.php in the application configuration directory (refer to the configuration file content for details).

If you need to run in daemon mode, you can use

php think swoole -d
Copy after login

or set

'daemonize' =>   true
Copy after login

in the swoole.php file. Note: Since there is no HTTP_HOST when onWorkerStart is running, the final Fortunately, setting app_host

in the application configuration file supports operations including

php think swoole [start|stop|reload|restart]
Copy after login

Since there is no HTTP_HOST when onWorkerStart is running, it is best to set the app_host parameter in the application configuration file

Once launched, your application can be accessed using

http://127.0.0.1:9501
Copy after login

.

If you need to configure the address and port, you can add the
swoole.php configuration file in the application configuration directory, and then set:

<?phpreturn [
    &#39;host&#39;  => &#39;tp5.com&#39;,
    &#39;port&#39;  =>   9508,];
可以支持Swoole自身的配置参数设置,例如:
<?phpreturn [
    &#39;host&#39;          => &#39;tp5.com&#39;,
    &#39;port&#39;          =>   9508,
    &#39;worker_num&#39;    =>   4,
    &#39;max_request&#39;   =>   1000,];
Copy after login

The onWorkerStart and onRequest event callback methods are defined in the extension ( Please do not substitute if you are not familiar with it). If you need to customize swoole's event callback method, you can use closure definition in the configuration file.

<?phpreturn [
    &#39;host&#39;          => &#39;tp5.com&#39;,
    &#39;port&#39;          =>   9508,
    &#39;worker_num&#39;    =>   4,
    &#39;max_request&#39;   =>   1000,
    &#39;WorkerStop&#39;    =>   function($server, $worker_id){
        // 添加你的代码
    },];
Copy after login

Or add it directly in the configuration file

Use Swoole as the Server

can support directly starting a Swoole server (requires 2.0.9 Version)

php think swoole:server

will start a Websocket service at 0.0.0.0:9508.

If you need custom parameters, you can configure them in config/swoole_server.php, including:

Configuration parameters
Description
typeService type
hostListening address
portListening port
modeRunning mode
socketSocket type

and supports all parameters of swoole.
Also supports using closures to define related event callbacks.

return [
    // 扩展自身配置
    &#39;host&#39;         => &#39;0.0.0.0&#39;, // 监听地址
    &#39;port&#39;         => 9501, // 监听端口
    &#39;type&#39;         => &#39;socket&#39;, // 服务类型 支持 socket http server
    &#39;mode&#39;         => SWOOLE_PROCESS,
    &#39;socket_type&#39;  => SWOOLE_SOCK_TCP,
 
    // 可以支持swoole的所有配置参数
    &#39;daemonize&#39;    => false,
 
    // 事件回调定义
    &#39;onOpen&#39;       => function ($server, $request) {
        echo "server: handshake success with fd{$request->fd}\n";
    },
 
    &#39;onMessage&#39;    => function ($server, $frame) {
        echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n";
        $server->push($frame->fd, "this is server");
    },
 
    &#39;onRequest&#39;    => function ($request, $response) {
        $response->end("<h1>Hello Swoole. #" . rand(1000, 9999) . "</h1>");
    },
 
    &#39;onClose&#39;      => function ($ser, $fd) {
        echo "client {$fd} closed\n";
    },];
Copy after login

You can also use a custom service class

<?php
namespace app\http;use think\swoole\Server;class Swoole extends Server{
    protected $host = &#39;127.0.0.1&#39;;
    protected $port = 9502;
    protected $option = [ 
        &#39;worker_num&#39;=> 4,
        &#39;daemonize&#39; => true,
        &#39;backlog&#39;   => 128
    ];
 
    public function onReceive($server, $fd, $from_id, $data)
    {
        $server->send($fd, &#39;Swoole: &#39;.$data);
    }}
Copy after login

Supports all callback method definitions of swoole (the callback method must be a public type)
If the serverType attribute is defined as socket or http, swoole is supported swoole_websocket_server and swoole_http_server

Then add configuration parameters in swoole_server.php:

return [
    &#39;swoole_class&#39;  =>   &#39;app\http\Swoole&#39;,];
Copy after login

After defining this parameter, other configuration parameters are no longer valid.

Start the server on the command line

php think swoole:server
Copy after login

Support reload|restart|stop|status operation

php think swoole:server reload
Copy after login

Recommended tutorial: "PHP Video Tutorial"

The above is the detailed content of Directly click on Swoole in Thinkphp. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:liqingbo.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template