centra_srv.php 3.0 KB

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