dispatcher.php 2.2 KB

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