HttpServerDataInf.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Administrator
  5. * Date: 2019/6/26
  6. * Time: 12:03
  7. */
  8. namespace datainf\logic;
  9. use App\Lib\ModelBase;
  10. use App\Http\Response\Response;
  11. use App\Logic\DataLogic;
  12. use Illuminate\Database\Capsule\Manager as DB;
  13. class HttpServerDataInf
  14. {
  15. private $httpserver;
  16. private $config;
  17. public function __construct($config)
  18. {
  19. $this->httpserver = new \swoole\http\server($config['host'], $config['port']);
  20. $this->httpserver->set($config['sets']);
  21. $this->config = $config;
  22. $this->httpserver->account = new \swoole\Atomic();
  23. $this->httpserver->taskWorkingNum = new \swoole\Atomic();
  24. $this->httpserver->on('request', array($this, 'OnRequest'));
  25. $this->httpserver->on('WorkerStart', array($this, 'onWorkerStart'));
  26. $this->httpserver->on('task', array($this, 'onTask'));
  27. $this->httpserver->on('finish', array($this, 'onFinish'));
  28. }
  29. public function onWorkerStart($serv, $worker_id)
  30. {
  31. /*
  32. $name = $serv->taskworker ? 'Task_' : 'Worker_';
  33. $name = 'Data_' . $name . ($serv->worker_id < 10 ? '0' . $serv->worker_id : $serv->worker_id);
  34. swoole_set_process_name($name);
  35. */
  36. $GLOBALS['model'] = '';
  37. $GLOBALS['modeltime'] = 0;
  38. $this->InitDb();
  39. if ($serv->worker_id == 0) {
  40. \Swoole\Timer::tick(60000, function () {
  41. $this->logRunStatus();
  42. if ($this->httpserver->taskWorkingNum->get() > 1) {
  43. $this->httpserver->taskWorkingNum->sub();
  44. }
  45. });
  46. }
  47. }
  48. private function logRunStatus()
  49. {
  50. echo date('Y-m-d H:i:s') . " 总请求数:" . $this->httpserver->account->get() . ' 运行任务数:' . $this->httpserver->taskWorkingNum->get();
  51. echo ' work_id:' . $this->httpserver->worker_id . " 内存使用量:" . (memory_get_usage() / 1000) . 'k 峰值:' . (memory_get_peak_usage() / 1000) . "k\n";
  52. }
  53. public function OnRequest($request, $response)
  54. {
  55. $response->header('Content-Type', 'text/html; charset=utf-8');
  56. $response->header('Server', 'DataInfaceServer');
  57. $paras = array_merge(['request_time' => date("H:i:s")], !empty($request->get) ? $request->get : [], !empty($request->post) ? $request->post : []);
  58. $this->httpserver->account->add();
  59. $request_uri = substr($request->server['request_uri'], 1);
  60. $urls = ['setLeague', 'setMatch', 'setMatchResult', 'setOdds', 'setOddsCH', 'setBroadCast', 'upMatch'];
  61. if (!in_array($request_uri, $urls)) {
  62. $data = Response::generate('', 0, '', '无效的url');
  63. $response->end($data);
  64. return;
  65. }
  66. $dataObj = json_decode($paras['data'], true);
  67. if (empty($dataObj)) {
  68. $data = Response::generate('', 5, '', '无效的data参数');
  69. $response->end($data);
  70. return;
  71. }
  72. if ($this->httpserver->taskWorkingNum->get() > intval($this->config['sets']['task_worker_num'])) {
  73. $data = Response::generate('', 9, '', '任务线程已满,请稍等...');
  74. $response->end($data);
  75. return;
  76. }
  77. $check_token = true;
  78. if ($check_token) {
  79. $token = isset($paras['token']) ? $paras['token'] : '';
  80. if (empty($token) || empty($this->Tokencheck($token))) {
  81. $data = Response::generate('', 6, '', '无效的token');
  82. $response->end($data);
  83. return;
  84. }
  85. }
  86. $this->onTask($this->httpserver, ['url' => $request_uri, 'paras' => $paras, 'respone' => $response]);
  87. $data = Response::generate('', 1, '');
  88. $response->end($data);
  89. return;
  90. }
  91. public function onTask($serv, $task)
  92. {
  93. $this->httpserver->taskWorkingNum->add();
  94. $url = $task['url'];
  95. $data = $task['paras'];
  96. switch ($url) {
  97. case 'setLeague':
  98. $ret = DataLogic::getInstance()->setLeague($data);
  99. break;
  100. case 'setMatch':
  101. $ret = DataLogic::getInstance()->setMatch($data);
  102. break;
  103. case 'setMatchResult':
  104. $ret = DataLogic::getInstance()->setMatchResult($data);
  105. break;
  106. case 'setOdds':
  107. $ret = DataLogic::getInstance()->setOdds($data);
  108. break;
  109. case 'setOddsCH':
  110. $ret = DataLogic::getInstance()->setOddsCH($data);
  111. break;
  112. case 'setBroadCast':
  113. $ret = DataLogic::getInstance()->setBroadCast($data);
  114. break;
  115. case 'upMatch':
  116. $ret = DataLogic::getInstance()->upMatch($data);
  117. break;
  118. default:
  119. $ret = 'false';
  120. break;
  121. }
  122. $this->httpserver->taskWorkingNum->sub();
  123. //$this->onFinish($serv, 0, $ret);
  124. }
  125. public function onFinish($serv, int $task_id, $data)
  126. {
  127. // print_r(['task_id' => $task_id, 'ret' => $data]);
  128. }
  129. private function Tokencheck($token)
  130. {
  131. $tokenvel = DB::table('system_user')->where(['token' => $token])->first();
  132. return $tokenvel;
  133. }
  134. private function InitDb()
  135. {
  136. $over_time = 60 * 5;
  137. $now = microtime(true);
  138. $debugmsg = 'manager_pid=' . $this->httpserver->manager_pid . ' master_pid=' . $this->httpserver->master_pid;
  139. $debugmsg .= ' worker_id=' . $this->httpserver->worker_id . ' worker_pid=' . $this->httpserver->worker_pid . ' istask=' . intval($this->httpserver->taskworker);
  140. if (!$GLOBALS['modeltime']) {
  141. $GLOBALS['modeltime'] = $now;
  142. $GLOBALS['model'] = $this->httpserver->worker_id;
  143. ModelBase::init();
  144. //echo "第一次建立数据库连接- $debugmsg .....\n";
  145. //echo $GLOBALS['modeltime'] . '--' . $GLOBALS['model'] . "\n";
  146. return;
  147. }
  148. if (($now - $GLOBALS['modeltime']) > $over_time) {
  149. $GLOBALS['modeltime'] = $now;
  150. $GLOBALS['model'] = $this->httpserver->worker_id;
  151. ModelBase::close();
  152. ModelBase::init();
  153. //echo "超时重连数据库-$debugmsg.....\n";
  154. //echo $GLOBALS['modeltime'] . '--' . $GLOBALS['model'] . "\n";
  155. return;
  156. }
  157. //echo "用的旧的连接-$debugmsg...." . $GLOBALS['modeltime'] . '--' . $GLOBALS['model'] . ".\n";
  158. }
  159. public function start()
  160. {
  161. $this->httpserver->start();
  162. }
  163. }