centra_srv.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. define('BASE_ROOT_PATH',str_replace('\\','/',dirname(__FILE__)));
  3. require_once (BASE_ROOT_PATH . '/fooder.php');
  4. require_once (BASE_ROOT_PATH . '/helper/search/server.php');
  5. require_once (BASE_ROOT_PATH . '/helper/search/processor.php');
  6. require_once (BASE_ROOT_PATH . '/helper/search/event_handler.php');
  7. require_once (BASE_ROOT_PATH . '/helper/search/util.php');
  8. require_once (BASE_ROOT_PATH . '/helper/category_helper.php');
  9. require_once (BASE_ROOT_PATH . '/helper/brand_helper.php');
  10. require_once (BASE_ROOT_PATH . '/helper/goods/commonid_helper.php');
  11. require_once (BASE_ROOT_PATH . '/helper/search/searcher.php');
  12. require_once (BASE_ROOT_PATH . '/helper/special_helper.php');
  13. require_once (BASE_ROOT_PATH . '/helper/search/area_library.php');
  14. require_once (BASE_ROOT_PATH . '/helper/brand_helper.php');
  15. require_once (BASE_ROOT_PATH . '/helper/algorithm.php');
  16. require_once (BASE_ROOT_PATH . '/helper/message/msgutil.php');
  17. require_once (BASE_ROOT_PATH . '/helper/message/subscriber.php');
  18. function all_channels()
  19. {
  20. return array('searcher');
  21. }
  22. $gMessageStates = null;
  23. $gMessageLock = null;
  24. function search_work($sockfd)
  25. {
  26. global $gMessageStates;
  27. global $gMessageLock;
  28. $gMessageStates = new MsgStates();
  29. $gMessageLock = Mutex::create();
  30. Base::run_util();
  31. StatesHelper::init();
  32. $listener = new message\subscriber($gMessageStates,$gMessageLock);
  33. $listener->start();
  34. if(StatesHelper::fetch_state('init')) {
  35. Log::record("StatesHelper::fetch_state first.",Log::DEBUG);
  36. search\searcher::instance()->init();
  37. search\area_library::instance();
  38. }
  39. search\CentraHelper::instance()->init(new search\processor());
  40. search\CentraHelper::instance()->run_loop($sockfd);
  41. }
  42. function fork_subprocess($count,$listen_fd)
  43. {
  44. if (($pid = pcntl_fork()) === 0)
  45. {
  46. //ob_end_clean(); // Discard the output buffer and close
  47. fclose(STDIN); // Close all of the standard
  48. fclose(STDOUT); // file descriptors as we
  49. fclose(STDERR); // are running as a daemon.
  50. Log::record("pid = {$pid} count = {$count} ",Log::DEBUG);
  51. search_work($listen_fd);
  52. exit();
  53. }
  54. elseif($pid === -1)
  55. {
  56. Log::record("pid = {$pid} count = {$count} ",Log::DEBUG);
  57. die('could not fork');
  58. }
  59. else
  60. {
  61. Log::record("pid = {$pid} count = {$count} ",Log::DEBUG);
  62. $ret = pcntl_waitpid($pid,$status,WNOHANG);
  63. if($ret == 0) {
  64. Log::record("spawn-fcgi: successful ret == 0 PID: {$pid}",Log::DEBUG);
  65. }
  66. elseif($ret == -1) {
  67. Log::record("spawn-fcgi: ret == 0 PID: {$pid}",Log::DEBUG);
  68. }
  69. else {
  70. Log::record("spawn-fcgi: ret == 0 child exited PID: {$pid}.",Log::DEBUG);
  71. }
  72. }
  73. }
  74. function remote_addr()
  75. {
  76. global $config;
  77. $host = $config['searcher']['host'];
  78. $port = $config['searcher']['port'];
  79. return "{$host}:{$port}";
  80. }
  81. $listen_fd = stream_socket_server (remote_addr(), $errno, $errstr);
  82. if($listen_fd == false) {
  83. echo "无法创建socket,请退出之前进程.\n";
  84. }
  85. $count = 1;
  86. while ($count-- > 0) {
  87. fork_subprocess($count,$listen_fd);
  88. }