Workerman ist ein asynchrones, ereignisgesteuertes PHP-Framework mit hoher Leistung, das die Erstellung schneller, skalierbarer Webanwendungen erleichtert. Unterstützt HTTP, Websocket, SSL und andere benutzerdefinierte Protokolle.
Wie verwende ich Workerman?
Erfordert
PHP 5.3 oder höher
Installation
Entpacken Sie es nach dem Herunterladen
Adresse: https://www.workerman.net/download
Workerman-Nutzungsschritte
Erstellen Sie einen gemeinsamen DAEMON
$worker = new Worker(); $worker::$pidFile = $config['pid']; $worker::$logFile = $config['log']; $worker->name = $config['title']; $worker->count = $config['num']; $worker->onWorkerStart = function($worker){ //执行一个回调函数 call_user_func('******'); }; Worker::runAll();
Erstellen Sie eine geplante Aufgabe (unterstützt die zweite Ebene)
count = 1; $task->onWorkerStart = function($task) { // 每1秒执行一次 支持小数,可以精确到0.001,即精确到毫秒级别 $time_interval = 1; Timer::add($time_interval, function() { echo "****\n"; }); }; Worker::runAll();
PHP sendet Nachrichten an den Client in Echtzeit
1. Erstellen Sie einen Websocket-Worker, um die lange Verbindung des Clients aufrechtzuerhalten
2. Erstellen Sie einen Text-Worker innerhalb des Websocket-Workers
3 . Websocket Worker und Text Worker sind derselbe Prozess und können problemlos Client-Verbindungen teilen
4. Ein unabhängiges PHP-Backend-System kommuniziert mit Text Worker über das Textprotokoll
5 Vollständiger Daten-Push
push.php
reusePort=true) */ $worker->count = 1; // worker进程启动后创建一个text Worker以便打开一个内部通讯端口 $worker->onWorkerStart = function($worker) { // 开启一个内部端口,方便内部系统推送数据,Text协议格式 文本+换行符 $inner_text_worker = new Worker('text://0.0.0.0:5678'); $inner_text_worker->onMessage = function($connection, $buffer) { // $data数组格式,里面有uid,表示向那个uid的页面推送数据 $data = json_decode($buffer, true); $uid = $data['uid']; // 通过workerman,向uid的页面推送数据 $ret = sendMessageByUid($uid, $buffer); // 返回推送结果 $connection->send($ret ? 'ok' : 'fail'); }; // ## 执行监听 ## $inner_text_worker->listen(); }; // 新增加一个属性,用来保存uid到connection的映射 $worker->uidConnections = array(); // 当有客户端发来消息时执行的回调函数 $worker->onMessage = function($connection, $data) { global $worker; // 判断当前客户端是否已经验证,既是否设置了uid if(!isset($connection->uid)) { // 没验证的话把第一个包当做uid(这里为了方便演示,没做真正的验证) $connection->uid = $data; /* 保存uid到connection的映射,这样可以方便的通过uid查找connection, * 实现针对特定uid推送数据 */ $worker->uidConnections[$connection->uid] = $connection; return; } }; listen // 当有客户端连接断开时 $worker->onClose = function($connection) { global $worker; if(isset($connection->uid)) { // 连接断开时删除映射 unset($worker->uidConnections[$connection->uid]); } }; // 向所有验证的用户推送数据 function broadcast($message) { global $worker; foreach($worker->uidConnections as $connection) { $connection->send($message); } } // 针对uid推送数据 function sendMessageByUid($uid, $message) { global $worker; if(isset($worker->uidConnections[$uid])) { $connection = $worker->uidConnections[$uid]; $connection->send($message); return true; } return false; } // 运行所有的worker Worker::runAll();
Back-End-Dienst starten
php push.php start -d
Front-End-Code
var ws = new WebSocket('ws://127.0.0.1:1234'); ws.onopen = function(){ var uid = 'uid1'; ws.send(uid); }; ws.onmessage = function(e){ alert(e.data); };
PHP-Backend-Code
// 建立socket连接到内部推送端口 $client = stream_socket_client('tcp://127.0.0.1:5678', $errno, $errmsg, 1); // 推送的数据,包含uid字段,表示是给这个uid推送 $data = array('uid'=>'uid1', 'percent'=>'88%'); // 发送数据,注意5678端口是Text协议的端口,Text协议需要在数据末尾加上换行符 fwrite($client, json_encode($data)."\n"); // 读取推送结果 echo fread($client, 8192);
Erstellen Sie einen einfachen Webserver
use \Workerman\Worker; use \Workerman\WebServer; require_once __DIR__ . '/Workerman/Autoloader.php'; // 这里监听8080端口,如果要监听80端口,需要root权限,并且端口没有被其它程序占用 $webserver = new WebServer('http://0.0.0.0:8080'); // 类似nginx配置中的root选项,添加域名与网站根目录的关联,可设置多个域名多个目录 $webserver->addRoot('www.example.com', '/your/path/of/web/'); $webserver->addRoot('blog.example.com', '/your/path/of/blog/'); // 设置开启多少进程 $webserver->count = 4; Worker::runAll();
Von Workerman unterstützte Funktionen
Reine PHP-Entwicklung, Multiprozessunterstützung, Unterstützung von PHP7, Unterstützung von HHVM
Unterstützung von TCP/UDP, eigenständige Unterstützung mehr als Millionen langer TCP-Verbindungen
Unterstützt die verteilte Bereitstellung, und der Cluster kann Millionen oder sogar mehr gleichzeitige TCP-Verbindungen unterstützen
Unterstützt das Libevent-Ereignis -ausgelöste Netzwerkbibliothek
Unterstützt Hot-Update und reibungslosen Serverneustart
Verfügt über viele Hochleistungskomponenten wie asynchrones MySQL, Redis, DNS, usw.
Die chinesische Website von PHP bietet eine große Anzahl kostenloserEinführungs-Tutorials für Arbeiter, die jeder gerne lernen kann!
Das obige ist der detaillierte Inhalt vonWie benutzt man Workerman?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!