资讯专栏INFORMATION COLUMN

thinkphp 6.0 swoole扩展websocket使用教程(think-swoole)

Julylovin / 903人阅读

摘要:前言即将迎来最新版本,针对目前越来越流行,也推出了最新的扩展。介绍即将推出的,已经适配并推出,并且默认适配了。和版本在使用方法上面有些许不同。其中的第一个参数和的第一个参数一致,作为事件名称。

前言
ThinkPHP即将迎来最新版本6.0,针对目前越来越流行Swoole,thinkphp也推出了最新的扩展think-swoole 3.0。
介绍

即将推出的tp6.0,已经适配swoole.并推出think-swoole 3.0,并且默认适配了socketio。和2.0版本在使用方法上面有些许不同。

Websocket 继承与Http,进行websocket连接之前需要一次HTTP请求,如果当期地址支持websocket则返回101,然后进行连接。也就是说并不是我的服务支持websocket后,请求每个连接地址都可以进行websocket连接,而是需要预先适配才可以连接。

参数配置

如果要使用websocket需要在配置中启用,将websocket下的enable设置为true

 "server"           => [
        "host"      => "0.0.0.0", // 监听地址
        "port"      => 808, // 监听端口
        "mode"      => SWOOLE_PROCESS, // 运行模式 默认为SWOOLE_PROCESS
        "sock_type" => SWOOLE_SOCK_TCP, // sock type 默认为SWOOLE_SOCK_TCP
        "options"   => [
            "pid_file"              => runtime_path() . "swoole.pid",
            "log_file"              => runtime_path() . "swoole.log",
            "daemonize"             => false,
            // Normally this value should be 1~4 times larger according to your cpu cores.
            "reactor_num"           => swoole_cpu_num(),
            "worker_num"            => swoole_cpu_num(),
            "task_worker_num"       => 4,//swoole_cpu_num(),
            "enable_static_handler" => true,
            "document_root"         => root_path("public"),
            "package_max_length"    => 20 * 1024 * 1024,
            "buffer_output_size"    => 10 * 1024 * 1024,
            "socket_buffer_size"    => 128 * 1024 * 1024,
            "max_request"           => 3000,
            "send_yield"            => true,
        ],
    ],
    "websocket"        => [
        "enabled"       => true,// 开启websocket
        "handler"       => Handler::class,  //自定义wbesocket绑定类
        "parser"        => Parser::class, //自定义解析类
        "route_file"    => base_path() . "websocket.php",
        "ping_interval" => 25000,
        "ping_timeout"  => 60000,
        "room"          => [
            "type"        => TableRoom::class,
            "room_rows"   => 4096,
            "room_size"   => 2048,
            "client_rows" => 8192,
            "client_size" => 2048,
        ],
    ],
    "auto_reload"      => true,
    "enable_coroutine" => true,
    "resetters"        => [],
    "tables"           => [],

handler和parser大大方便了自定义websocket服务,默认系统集成socketio。

本文主要介绍如何使用socketio,这里假设大家有socketio有一定了解和使用基础。

socketIo默认会在请求地址后加相应的参数

同时,socketio默认情况下,会认为 http://url/socket.io/ 是支持websocket服务的地址。

而在tp-swoole3.0内部已经对该地址请求进行了处理

param("transport"), $this->transports)) {
            return json(
                [
                    "code"    => 0,
                    "message" => "Transport unknown",
                ],
                400
            );
        }

        if ($request->has("sid")) {
            $response = response("1:6");
        } else {
            $sid     = base64_encode(uniqid());
            $payload = json_encode(
                [
                    "sid"          => $sid,
                    "upgrades"     => ["websocket"],
                    "pingInterval" => $config->get("swoole.websocket.ping_interval"),
                    "pingTimeout"  => $config->get("swoole.websocket.ping_timeout"),
                ]
            );
            $cookie->set("io", $sid);
            $response = response("97:0" . $payload . "2:40");
        }

        return $response->contentType("text/plain");
    }

    public function reject(Request $request)
    {
        return json(
            [
                "code"    => 3,
                "message" => "Bad request",
            ],
            400
        );
    }
}

TP6.0,插件注册采用了service方式进行了注册,可在tp-swoole 服务注册文件中查看路由注册信息,如果想自定义链接规则,则可以覆盖该路由。


// +----------------------------------------------------------------------

namespace thinkswoole;

use SwooleHttpServer as HttpServer;
use SwooleWebsocketServer as WebsocketServer;
use thinkApp;
use thinkRoute;
use thinkswoolecommandServer as ServerCommand;
use thinkswoolefacadeServer;
use thinkswoolewebsocketsocketioController;
use thinkswoolewebsocketsocketioMiddleware;

class Service extends 	hinkService
{
    protected $isWebsocket = false;

    /**
     * @var HttpServer | WebsocketServer
     */
    protected static $server;

    public function register()
    {
        $this->isWebsocket = $this->app->config->get("swoole.websocket.enabled", false);

        $this->app->bind(Server::class, function () {
            if (is_null(static::$server)) {
                $this->createSwooleServer();
            }

            return static::$server;
        });

        $this->app->bind("swoole.server", Server::class);

        $this->app->bind(Swoole::class, function (App $app) {
            return new Swoole($app);
        });

        $this->app->bind("swoole", Swoole::class);
    }

    public function boot(Route $route)
    {
        $this->commands(ServerCommand::class);
        if ($this->isWebsocket) {
            $route->group(function () use ($route) {
                $route->get("socket.io/", "@upgrade");
                $route->post("socket.io/", "@reject");
            })->prefix(Controller::class)->middleware(Middleware::class);
        }
    }

    /**
     * Create swoole server.
     */
    protected function createSwooleServer()
    {
        $server     = $this->isWebsocket ? WebsocketServer::class : HttpServer::class;
        $config     = $this->app->config;
        $host       = $config->get("swoole.server.host");
        $port       = $config->get("swoole.server.port");
        $socketType = $config->get("swoole.server.socket_type", SWOOLE_SOCK_TCP);
        $mode       = $config->get("swoole.server.mode", SWOOLE_PROCESS);

        static::$server = new $server($host, $port, $mode, $socketType);

        $options = $config->get("swoole.server.options");

        static::$server->set($options);
    }
}

Socketio默认使用demo




    
    Title
    




Websocket路由配置方法

在app目录下新建websocket.php文件,其中需要注意,由于使用了反射,闭包参数名称不能随意定义,不然无法注入。第一个参数是websocket,是当前websocket的Server对象,第二个参数data是客户端发送的数据。其中socketio emit的第一个参数和Websocket::on的第一个参数一致,作为事件名称。

emit("test", "asd");
});

Websocket::on("test1", function ($websocket, $data) {
    $websocket->emit("test", "asd");
});

Websocket::on("join", function (	hinkswooleWebsocket $websocket, $data) {
    $websocket->join("1");
});

参考如上方法即可使用全新的websocket服务。当然tp-swoole3.0同样还有许多其他的新功能,这些功能需要大家去摸索尝试。
我也会在接下来的文章中,一起与大家分享我的使用过程。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/31832.html

相关文章

  • think-swoole 3.0入门教程thinkphp 6.0

    摘要:前言即将迎来最新版本,针对目前越来越流行,也推出了最新的扩展安装由于目前没有稳定版本,所以只能安装开发板接下来安装,目前最新的稳定版本是配置安装结束可以根据自己的需求对配置信息进行修改。 前言 ThinkPHP即将迎来最新版本6.0,针对目前越来越流行Swoole,thinkphp也推出了最新的扩展think-swoole 3.0 安装 由于目前thinkphp 6.0没有稳定版本,所...

    Bamboy 评论0 收藏0
  • think-swoole 3.0入门教程thinkphp 6.0)架构分析 1

    摘要:如下图目录结构主要针对的是非常驻内存方式运行,为了兼容,虽然做了很多优化,但是仍然无法像,等一些针对开发的框架一样。在非常住内存框架中,为了方便会有一些写法导致在常驻内存方式下不容易被释放内存,小则内存泄漏,大则数据错乱。 前言 ThinkPHP即将迎来最新版本6.0,针对目前越来越流行Swoole,thinkphp也推出了最新的扩展think-swoole 3.0 架构分析 tp-s...

    Coding01 评论0 收藏0
  • think-swoole 3.0入门教程thinkphp 6.0)架构分析 2

    摘要:由于是基于容器创建和销毁资源的,那么各个容器之间是相对隔离的。也就是说每次请求都会创建一个新的环境用于执行和解析,由于容器的隔离性,每个请求都不会和其他请求进行干扰。因为只有当前协程才可以读取到该数据。 前言 ThinkPHP即将迎来最新版本6.0,针对目前越来越流行Swoole,thinkphp也推出了最新的扩展think-swoole 3.0 沙盒 本文主要介绍在ThinkPHP-...

    Shonim 评论0 收藏0
  • 《当 Swoole 遇上 ThinkPHP5》:Hello,World!

    摘要:安装框架安装如果已经安装了可以跳过本步骤,但是请确定通过命令来确保已经使用了最新版本的使用以下命令可以直接通过官网下载并自动安装到目录下如果以上安装过程极慢的话,可以尝试用以下方式通过国内镜像来安装。 《当 Swoole 遇上 ThinkPHP5》:Hello,World! 本文假设你已经有了 Linux 操作系统的 PHP 环境,强烈推荐使用 Vagrant 来搭建开发环境 安装 ...

    xzavier 评论0 收藏0
  • swoolefy-基于swoole扩展实现的高性能的常驻内存型API和Web应用服务框架

    摘要:是一个基于扩展实现的轻量级高性能的常驻内存型的和应用服务框架高度封装了,,服务器,以及基于实现可扩展的服务,同时支持包方式安装部署项目。基于实用,抽象事件处理类,实现与底层的回调的解耦,支持同步异步调用,内置等常用组件等。 swoolefy swoolefy是一个基于swoole扩展实现的轻量级高性能的常驻内存型的API和Web应用服务框架,高度封装了http,websocket,ud...

    lewinlee 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<