centra_srv.php 3.2 KB

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