国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

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

Julylovin / 1231人閱讀

摘要:前言即將迎來最新版本,針對目前越來越流行,也推出了最新的擴展。介紹即將推出的,已經適配并推出,并且默認適配了。和版本在使用方法上面有些許不同。其中的第一個參數和的第一個參數一致,作為事件名稱。

前言
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同樣還有許多其他的新功能,這些功能需要大家去摸索嘗試。
我也會在接下來的文章中,一起與大家分享我的使用過程。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/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元查看
<