ThinkPHP6 Basic use of Workerman
Workerman
Workerman is an open source developed purely in PHP High-performance PHP socket server framework. It is widely used in the development of mobile apps, mobile game servers, online game servers, chat room servers, hardware communication servers, smart homes, Internet of Vehicles, Internet of Things and other fields. Supports TCP long connections, supports Websocket, HTTP and other protocols, and supports custom protocols. Based on Workerman, developers can focus more on business logic development and no longer have to worry about the underlying development of PHP Socket.
Related recommendations: "workerman Tutorial"
Installation
First install through composer
composer require topthink/think-worker
Use
Use Workerman as HttpServer
Start the server on the command line
php think worker
Then you can directly access the current application through the browser
http://localhost:2346
Linux can support the following commands
php think worker [start|stop|reload|restart|status]
The parameters of workererman can be configured in worker.php in the application configuration directory.
Since there is no HTTP_HOST when onWorkerStart is running, it is best to set app_host in the application configuration file
SocketServer
Start the server on the command line ( Requires version 2.0.5)
php think worker:server
A websocket service will be opened at 0.0.0.0:2345 by default.
If you need custom parameters, you can configure them in config/worker_server.php, including:
and supports all parameters of workererman (including global static parameters).
also supports using closures to define related event callbacks.
return [ 'socket' => 'http://127.0.0.1:8000', 'name' => 'thinkphp', 'count' => 4, 'onMessage' => function($connection, $data) { $connection->send(json_encode($data)); }, ];
also supports using custom classes as Worker service entry file classes. For example, we can create a service class (must inherit think\worker\Server), then set properties and add callback methods
<?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)); } }
Supports all callback method definitions of workererman (callback methods must be public types)
Then add configuration parameters in worker_server.php:
return [ 'worker_class' => 'app\http\Worker', ];
After defining this parameter, other configuration parameters will no longer be valid.
Start the server on the command line
php think worker:server
Then access it in the browser
http://localhost:2346
If under Linux, reload|restart|stop is also supported |status operation
php think worker:server reload
Recommended tutorial: "PHP"
The above is the detailed content of Using Workerman in ThinkPHP6. For more information, please follow other related articles on the PHP Chinese website!