pipe_message.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. <?php
  2. $serv = new swoole_server("0.0.0.0", 9501, SWOOLE_BASE);
  3. //$serv = new swoole_server("0.0.0.0", 9501);
  4. $serv->set(array(
  5. 'worker_num' => 2,
  6. 'task_worker_num' => 2,
  7. ));
  8. $serv->on('pipeMessage', function($serv, $src_worker_id, $data) {
  9. echo "#{$serv->worker_id} message from #$src_worker_id: $data\n";
  10. });
  11. $serv->on('task', function (swoole_server $serv, $task_id, $reactor_id, $data){
  12. echo "#{$serv->worker_id} NewTask: $data\n";
  13. $serv->sendMessage($data, 0);
  14. //$serv->send($fd, str_repeat('B', 1024*rand(40, 60)).rand(10000, 99999)."\n");
  15. });
  16. $serv->on('finish', function ($serv, $fd, $reactor_id){
  17. });
  18. $serv->on('receive', function (swoole_server $serv, $fd, $reactor_id, $data) {
  19. $cmd = trim($data);
  20. if($cmd == 'totask')
  21. {
  22. $serv->sendMessage("hello task process", 2);
  23. }
  24. elseif($cmd == 'toworker')
  25. {
  26. $worker_id = 1 - $serv->worker_id;
  27. $serv->sendMessage("hello worker", $worker_id);
  28. }
  29. elseif($cmd == 'task2worker')
  30. {
  31. $serv->task('hello worker from task.');
  32. }
  33. else
  34. {
  35. echo "#{$serv->worker_id} Recv: $data\n";
  36. }
  37. });
  38. $serv->on('close', function ($serv, $fd, $reactor_id) {
  39. //echo "[#".posix_getpid()."]\tClient@[$fd:$reactor_id]: Close.\n";
  40. });
  41. $serv->start();