在业务逻辑目录建立启动文件
启动文件引用Workerman的类加载文件
根据自身需要,选择具体的应用层协议: 如http、websocket等。并实例化Worker对象,编写对应的回调方法
命令行执行启动文件
测试
修改代码后,测试不生效
这是因为Workerman是基于命令行的运行方式,是一种常驻内存的方式。这就意味着修改代码后,如不重启(销毁内存代码),则代码还是旧的
开启多个服务时时,需要多个终端才能执行吗?
可以采用如下方式:
– 采用守护进程的方式执行,由于是守护进程运行,因此每次在终端执行完命令后,不占终端。
– 编写统一启动入口文件,由统一启动入口文件引用各个服务的启动文件
3、统一启动入口文件案例演示这里采用websocket的例子
3.1、统一启动入口文件-start.php3.2、web服务文件-start_web.phprequire_once __DIR__ . ‘/Autoloader.php’;
use WorkermanWorker;
define(‘RUN’,1);
// 加载所有Applications/*/start.php,以便启动所有服务
foreach(glob(__DIR__.’/start_*.php’) as $start_file)
{
require_once $start_file;
}
Worker::runAll();
3.3、websocket服务文件-start_websocket.phprequire_once __DIR__.”/Autoloader.php”;
use WorkermanWorker;
use WorkermanWebServer;
$web = new WebServer(“http://0.0.0.0:2347”);
$web->addRoot(”,__DIR__.”/html/”);
if (!defined(‘RUN’)) {
Worker::runAll();
}
4、启动require_once __DIR__.”/Autoloader.php”;
use WorkermanWorker;
$ws = new Worker(“websocket://0.0.0.0:2348”);
$ws->onConnect = function($connection) {
echo “new connection”,PHP_EOL;
};
$ws->onMessage = function($connection,$data) {
$connection->send(“you input data is:”.$data);
};
$ws->onClose = function($connection){
echo “close connection”,PHP_EOL;
};
if (!defined(‘RUN’)) {
Worker::runAll();
}
php start.php start



