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
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 = 'http://0.0.0.0:2346'; 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 [ 'worker_class' => 'app\http\Worker', ];
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!