123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- <?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_onClose($serv, $fd, $reactor_id)
- {
- //echo "Client: fd=$fd is closed.\n";
- }
- function my_onConnect($serv, $fd, $reactor_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, $reactor_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, $reactor_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']."_".$reactor_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('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();
|