Verwendung von Workerman in ThinkPHP6

Guanhui
Freigeben: 2021-02-01 12:02:51
nach vorne
9674 Leute haben es durchsucht

Verwendung von Workerman in ThinkPHP6

Grundlegende Verwendung von ThinkPHP6 Workerman

Workerman

Workerman ist eine Open Source, die ausschließlich in entwickelt wurde PHP Hochleistungsfähiges PHP-Socket-Server-Framework. 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.

Verwandte Empfehlungen: „Workerman-Tutorial

Installation

Erste Installation über Composer

composer require topthink/think-worker
Nach dem Login kopieren

Verwenden Sie

Verwenden Sie Workerman als HttpServer

Starten Sie den Server in der Befehlszeile

php think worker
Nach dem Login kopieren

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

http://localhost:2346
Nach dem Login kopieren
Nach dem Login kopieren

Linux unterstützt die folgenden Befehle

php think worker [start|stop|reload|restart|status]
Nach dem Login kopieren

Die Parameter von workererman können in worker.php im Anwendungskonfigurationsverzeichnis konfiguriert werden.

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
Nach dem Login kopieren
Nach dem Login kopieren

ö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:

und unterstützt alle Worker-Parameter (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));
 },
];
Nach dem Login kopieren

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));
 }
}
Nach dem Login kopieren

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 dem Login kopieren

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

Starten Sie den Server auf der Befehlszeile

php think worker:server
Nach dem Login kopieren
Nach dem Login kopieren

Greifen Sie dann im Browser auf

http://localhost:2346
Nach dem Login kopieren
Nach dem Login kopieren

zu, wenn dieser unter Linux läuft, neu laden|neu starten|stoppen unterstützt auch |Statusoperation

php think worker:server reload
Nach dem Login kopieren

Empfohlenes Tutorial: „PHP

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

Verwandte Etiketten:
Quelle:juejin.im
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage