143 lines
3.9 KiB
PHP
Executable File
143 lines
3.9 KiB
PHP
Executable File
<?php
|
|
$serv = new swoole_server("127.0.0.1", 9501);
|
|
|
|
$serv->set(array(
|
|
'worker_num' => 1,
|
|
//'open_eof_check' => true,
|
|
//'package_eof' => "\r\n",
|
|
'task_worker_num' => 1,
|
|
//'dispatch_mode' => 2,
|
|
//'daemonize' => 1,
|
|
//'heartbeat_idle_time' => 5,
|
|
//'heartbeat_check_interval' => 5,
|
|
));
|
|
function my_onStart($serv)
|
|
{
|
|
echo "MasterPid={$serv->master_pid}|Manager_pid={$serv->manager_pid}\n";
|
|
echo "Server: start.Swoole version is [".SWOOLE_VERSION."]\n";
|
|
//$serv->addtimer(1000);
|
|
}
|
|
|
|
function my_onShutdown($serv)
|
|
{
|
|
echo "Server: onShutdown\n";
|
|
}
|
|
|
|
function my_onTimer($serv, $interval)
|
|
{
|
|
echo "Server:Timer Call.Interval=$interval\n";
|
|
}
|
|
|
|
function my_onClose($serv, $fd, $from_id)
|
|
{
|
|
//echo "Client: fd=$fd is closed.\n";
|
|
}
|
|
|
|
function my_onConnect($serv, $fd, $from_id)
|
|
{
|
|
//throw new Exception("hello world");
|
|
// echo "Client:Connect.\n";
|
|
}
|
|
|
|
function my_onWorkerStart($serv, $worker_id)
|
|
{
|
|
global $argv;
|
|
if ($worker_id >= $serv->setting['worker_num']) {
|
|
swoole_set_process_name("php {$argv[0]} task worker");
|
|
} else {
|
|
swoole_set_process_name("php {$argv[0]} event worker");
|
|
}
|
|
//echo "WorkerStart|MasterPid={$serv->master_pid}|Manager_pid={$serv->manager_pid}|WorkerId=$worker_id\n";
|
|
//$serv->addtimer(500); //500ms
|
|
}
|
|
|
|
function my_onWorkerStop($serv, $worker_id)
|
|
{
|
|
echo "WorkerStop[$worker_id]|pid=".posix_getpid().".\n";
|
|
}
|
|
|
|
function my_onReceive(swoole_server $serv, $fd, $from_id, $rdata)
|
|
{
|
|
$data = unserialize($rdata);
|
|
if (isset($data['cmd']))
|
|
{
|
|
switch ($data['cmd'])
|
|
{
|
|
case 'get':
|
|
$s = microtime(true);
|
|
$res = $serv->taskwait($data, 0.5, 0);
|
|
echo "use " . ((microtime(true) - $s) * 1000) . "ms\n";
|
|
$serv->send($fd, PHP_EOL . "get " . $res['key'] . ": " . $res['val']);
|
|
break;
|
|
case "set":
|
|
$serv->task($data, 0);
|
|
$serv->send($fd, "OK\n");
|
|
break;
|
|
case "del":
|
|
$serv->task($data, 0);
|
|
break;
|
|
case "reload":
|
|
break;
|
|
default:
|
|
echo "server:" . $data . PHP_EOL;
|
|
}
|
|
}
|
|
}
|
|
|
|
function my_onTask(swoole_server $serv, $task_id, $from_id, $data)
|
|
{
|
|
static $datas = array();
|
|
if (isset($data['cmd']))
|
|
{
|
|
switch ($data['cmd']) {
|
|
case 'get':
|
|
$key = $data['key'];
|
|
$val = isset($datas[$key]) ? $datas[$key] : "";
|
|
$serv->finish(array('key'=>$key, 'val' => $val));
|
|
break;
|
|
case "set":
|
|
$key = $data['key'];
|
|
$val = $data['val']."_".$from_id;
|
|
$datas[$key] = $val;
|
|
return;
|
|
break;
|
|
case "del":
|
|
$key = $data['key'];
|
|
if(isset($datas[$key])) {
|
|
unset($datas[$key]);
|
|
}
|
|
break;
|
|
case "task":
|
|
$key = $data['key'];
|
|
echo "Do task " . $key . PHP_EOL;
|
|
break;
|
|
}
|
|
}
|
|
echo "AsyncTask[PID=".posix_getpid()."]: task_id=$task_id.".PHP_EOL;
|
|
// $serv->finish("OK");
|
|
}
|
|
|
|
function my_onFinish(swoole_server $serv, $task_id, $from_worker_id, $data)
|
|
{
|
|
echo "AsyncTask Finish: Connect.PID=" . posix_getpid() . PHP_EOL;
|
|
}
|
|
|
|
function my_onWorkerError(swoole_server $serv, $worker_id, $worker_pid, $exit_code)
|
|
{
|
|
echo "worker abnormal exit. WorkerId=$worker_id|Pid=$worker_pid|ExitCode=$exit_code\n";
|
|
}
|
|
|
|
$serv->on('Start', 'my_onStart');
|
|
$serv->on('Connect', 'my_onConnect');
|
|
$serv->on('Receive', 'my_onReceive');
|
|
$serv->on('Close', 'my_onClose');
|
|
$serv->on('Shutdown', 'my_onShutdown');
|
|
$serv->on('Timer', 'my_onTimer');
|
|
$serv->on('WorkerStart', 'my_onWorkerStart');
|
|
$serv->on('WorkerStop', 'my_onWorkerStop');
|
|
$serv->on('Task', 'my_onTask');
|
|
$serv->on('Finish', 'my_onFinish');
|
|
$serv->on('WorkerError', 'my_onWorkerError');
|
|
$serv->start();
|
|
|