Heim >PHP-Framework >Denken Sie an PHP >Grundlegende Verwendung von ThinkPHP6 Workerman

Grundlegende Verwendung von ThinkPHP6 Workerman

Guanhui
Guanhuinach vorne
2020-05-13 09:51:159404Durchsuche

Workerman

Workerman ist ein Open-Source-Hochleistungs-PHP-Socket-Server-Framework, das rein in PHP entwickelt wurde. Es wird häufig in der Entwicklung von mobilen Apps, mobilen Spieleservern, Online-Spieleservern, Chatroom-Servern, Hardware-Kommunikationsservern, Smart Homes, dem Internet der Fahrzeuge, dem Internet der Dinge und anderen Bereichen eingesetzt. Unterstützt lange TCP-Verbindungen, unterstützt Websocket, HTTP und andere Protokolle sowie benutzerdefinierte Protokolle. Basierend auf Workerman können sich Entwickler mehr auf die Entwicklung der Geschäftslogik konzentrieren und müssen sich nicht mehr um die zugrunde liegende Entwicklung von PHP Socket kümmern.

Installieren

Erste Installation

composer require topthink/think-worker
über Composer

Verwenden Sie

Verwenden Sie Workerman als HttpServer

Starten Sie den Server in der Befehlszeile

php think worker

Dann können Sie über den Browser direkt auf die aktuelle Anwendung zugreifen

http://localhost:2346

Linux kann die folgenden Befehle unterstützen

php think worker [start|stop|reload|restart|status]

workerman-Parameter kann sein Konfigurieren Sie es in worker.php im Anwendungskonfigurationsverzeichnis.

Da es keinen HTTP_HOST gibt, wenn onWorkerStart ausgeführt wird, ist es am besten, app_host in der Anwendungskonfigurationsdatei festzulegen

SocketServer

Starten Sie den Server auf Die Befehlszeile (erfordert Version 2.0.5+)

php think worker:server

öffnet standardmäßig einen Websocket-Dienst unter 0.0.0.0:2345.

Wenn Sie benutzerdefinierte Parameter benötigen, können Sie diese in config/worker_server.php konfigurieren, einschließlich:

配置参数 描述
protocol 协议
host 监听地址
port 监听端口
socket 完整的socket地址

und unterstützt alle Parameter von workererman (einschließlich globaler statischer Parameter).

unterstützt auch die Verwendung von Abschlüssen zum Definieren zugehöriger Ereignisrückrufe.

return [
    'socket'    =>  'http://127.0.0.1:8000',
    'name'      =>  'thinkphp',
    'count'     =>  4,
    'onMessage' =>  function($connection, $data) {
        $connection->send(json_encode($data));
    },
];

unterstützt auch die Verwendung benutzerdefinierter Klassen als Worker-Service-Eintragsdateiklassen. Beispielsweise können wir eine Serviceklasse erstellen (muss thinkworkerServer erben), dann Eigenschaften festlegen und Rückrufmethoden hinzufügen

<?php
namespace app\http;
use think\worker\Server;
class Worker extends Server
{
    protected $socket = &#39;http://0.0.0.0:2346&#39;;
    public function onMessage($connection,$data)
    {
        $connection->send(json_encode($data));
    }
}

unterstützt alle Rückrufmethodendefinitionen von workererman (Rückrufmethoden müssen öffentliche Typen sein)

Fügen Sie dann den Konfigurationsparameter in worker_server.php hinzu:

return [
    &#39;worker_class&#39;  =>  &#39;app\http\Worker&#39;,
];

Nach der Definition dieses Parameters sind andere Konfigurationsparameter nicht mehr gültig.

Starten Sie den Server in der Befehlszeile

php think worker:server

und greifen Sie dann im Browser auf

http://localhost:2346

zu. Wenn es unter Linux läuft, ist der Vorgang „reload|restart|stop|status“. wird auch unterstützt

php think worker:server reload

Empfohlene Tutorials: „ThinkPHP“ „PHP Tutorial“ „Workerman Tutorial

Das obige ist der detaillierte Inhalt vonGrundlegende Verwendung von ThinkPHP6 Workerman. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:kancloud.cn. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen