dispatcher.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?php
  2. declare(strict_types=0);
  3. define('APP_ID', 'rdispatcher');
  4. define('MOBILE_SERVER',true);
  5. define('BASE_ROOT_PATH',str_replace('/rdispatcher','',dirname(__FILE__)));
  6. define('BASE_PATH',BASE_ROOT_PATH . '/rdispatcher');
  7. require_once(BASE_ROOT_PATH . '/global.php');
  8. require_once(BASE_ROOT_PATH . '/fooder.php');
  9. Log::record("1",Log::DEBUG);
  10. require_once(BASE_HELPER_PATH . '/event_looper.php');
  11. require_once(BASE_HELPER_PATH . '/queue/rdispatcher.php');
  12. Log::record("2",Log::DEBUG);
  13. Log::record(BASE_HELPER_RAPI_PATH,Log::DEBUG);
  14. require_once(BASE_HELPER_PATH . '/refill/RefillFactory.php');
  15. require_once(BASE_HELPER_PATH . '/algorithm.php');
  16. Log::record("3",Log::DEBUG);
  17. require_once(BASE_PATH . '/processor.php');
  18. require_once(BASE_PATH . '/proxy.php');
  19. //这个可以
  20. //Co::set(['hook_flags' => SWOOLE_HOOK_ALL ^ SWOOLE_HOOK_TCP ^ SWOOLE_HOOK_UDP ^
  21. // SWOOLE_HOOK_FILE ^ SWOOLE_HOOK_UNIX ^
  22. // SWOOLE_HOOK_STREAM_FUNCTION ^
  23. // SWOOLE_HOOK_BLOCKING_FUNCTION ^
  24. // SWOOLE_HOOK_PROC ^
  25. // SWOOLE_HOOK_SLEEP ^
  26. // SWOOLE_HOOK_TLS ^
  27. // SWOOLE_HOOK_SSL
  28. //]);
  29. //这样会导致,curl 协程部分不执行,收不到数据
  30. //Co::set(['hook_flags' => SWOOLE_HOOK_NATIVE_CURL | SWOOLE_HOOK_SOCKETS]);
  31. //这样会导致,redis任何阻塞函数不返回
  32. //Co::set(['hook_flags' => SWOOLE_HOOK_ALL]);
  33. //目前没发现问题
  34. Co::set(['hook_flags' => SWOOLE_HOOK_ALL ^ SWOOLE_HOOK_TCP]);
  35. if (empty($_SERVER['argv'][1])) exit('parameter error');
  36. $count = intval($_SERVER['argv'][1]);
  37. function all_channels() {
  38. return ['refill'];
  39. }
  40. function handle_error($level, $message, $file, $line)
  41. {
  42. if($level == E_NOTICE) return;
  43. $trace = "handle_error: level={$level},msg={$message} file={$file},line={$line}\n";
  44. $backtrace = debug_backtrace();
  45. foreach ($backtrace as $item) {
  46. $trace .= "{$item['file']}\t{$item['line']}\t{$item['function']}\n";
  47. }
  48. Log::record($trace,Log::ERR);
  49. }
  50. function work_proc()
  51. {
  52. Base::run_util();
  53. set_error_handler('handle_error');
  54. $looper = new processor();
  55. $looper->run();
  56. }
  57. //swoole 和 pthreads 冲突
  58. function corun()
  59. {
  60. Log::record("start run process",Log::DEBUG);
  61. Co\run(function() {
  62. work_proc();
  63. });
  64. }
  65. event\util::fork_workerex('corun',$count);