HttpServerDataInf.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  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. });
  43. }
  44. if ($serv->worker_id == 1) {
  45. \Swoole\Timer::tick(3000, function () {
  46. if ($this->httpserver->taskWorkingNum->get() > 1) {
  47. $this->httpserver->taskWorkingNum->sub();
  48. }
  49. });
  50. }
  51. }
  52. private function logRunStatus()
  53. {
  54. echo date('Y-m-d H:i:s') . " 总请求数:" . $this->httpserver->account->get() . ' 运行任务数:' . $this->httpserver->taskWorkingNum->get();
  55. echo ' work_id:' . $this->httpserver->worker_id . " 内存使用量:" . (memory_get_usage() / 1000) . 'k 峰值:' . (memory_get_peak_usage() / 1000) . "k\n";
  56. }
  57. public function OnRequest($request, $response)
  58. {
  59. $response->header('Content-Type', 'text/html; charset=utf-8');
  60. $response->header('Server', 'DataInfaceServer');
  61. $paras = array_merge(['request_time' => date("H:i:s")], !empty($request->get) ? $request->get : [], !empty($request->post) ? $request->post : []);
  62. $this->httpserver->account->add();
  63. $request_uri = substr($request->server['request_uri'], 1);
  64. $urls = ['setLeague', 'setMatch', 'setMatchResult', 'setOdds', 'setOddsCH', 'setBroadCast', 'upMatch'];
  65. if (!in_array($request_uri, $urls)) {
  66. $data = Response::generate('', 0, '', '无效的url');
  67. $response->end($data);
  68. return;
  69. }
  70. $dataObj = json_decode($paras['data'], true);
  71. if (empty($dataObj)) {
  72. $data = Response::generate('', 5, '', '无效的data参数');
  73. $response->end($data);
  74. return;
  75. }
  76. if ($this->httpserver->taskWorkingNum->get() > intval($this->config['sets']['task_worker_num'])) {
  77. $str = $this->httpserver->taskWorkingNum->get() . '/' . $this->config['sets']['task_worker_num'];
  78. $data = Response::generate('', 9, '', '任务线程已满,请稍等...' . $str);
  79. $response->end($data);
  80. return;
  81. }
  82. $check_token = true;
  83. if ($check_token) {
  84. $token = isset($paras['token']) ? $paras['token'] : '';
  85. if (empty($token) || empty($this->Tokencheck($token))) {
  86. $data = Response::generate('', 6, '', '无效的token');
  87. $response->end($data);
  88. return;
  89. }
  90. }
  91. $this->onTask($this->httpserver, ['url' => $request_uri, 'paras' => $paras, 'respone' => $response]);
  92. $data = Response::generate('', 1, '');
  93. $response->end($data);
  94. return;
  95. }
  96. public function onTask($serv, $task)
  97. {
  98. $this->httpserver->taskWorkingNum->add();
  99. $url = $task['url'];
  100. $data = $task['paras'];
  101. switch ($url) {
  102. case 'setLeague':
  103. $ret = DataLogic::getInstance()->setLeague($data);
  104. break;
  105. case 'setMatch':
  106. $ret = DataLogic::getInstance()->setMatch($data);
  107. break;
  108. case 'setMatchResult':
  109. $ret = DataLogic::getInstance()->setMatchResult($data);
  110. break;
  111. case 'setOdds':
  112. $ret = DataLogic::getInstance()->setOdds($data);
  113. break;
  114. case 'setOddsCH':
  115. $ret = DataLogic::getInstance()->setOddsCH($data);
  116. break;
  117. case 'setBroadCast':
  118. $ret = DataLogic::getInstance()->setBroadCast($data);
  119. break;
  120. case 'upMatch':
  121. $ret = DataLogic::getInstance()->upMatch($data);
  122. break;
  123. default:
  124. $ret = 'false';
  125. break;
  126. }
  127. if ($this->httpserver->taskWorkingNum->get() > 1) {
  128. $this->httpserver->taskWorkingNum->sub();
  129. }
  130. //$this->onFinish($serv, 0, $ret);
  131. }
  132. public function onFinish($serv, int $task_id, $data)
  133. {
  134. // print_r(['task_id' => $task_id, 'ret' => $data]);
  135. }
  136. private function Tokencheck($token)
  137. {
  138. $tokenvel = DB::table('system_user')->where(['token' => $token])->first();
  139. return $tokenvel;
  140. }
  141. private function InitDb()
  142. {
  143. $over_time = 60 * 5;
  144. $now = microtime(true);
  145. $debugmsg = 'manager_pid=' . $this->httpserver->manager_pid . ' master_pid=' . $this->httpserver->master_pid;
  146. $debugmsg .= ' worker_id=' . $this->httpserver->worker_id . ' worker_pid=' . $this->httpserver->worker_pid . ' istask=' . intval($this->httpserver->taskworker);
  147. if (!$GLOBALS['modeltime']) {
  148. $GLOBALS['modeltime'] = $now;
  149. $GLOBALS['model'] = $this->httpserver->worker_id;
  150. ModelBase::init();
  151. //echo "第一次建立数据库连接- $debugmsg .....\n";
  152. //echo $GLOBALS['modeltime'] . '--' . $GLOBALS['model'] . "\n";
  153. return;
  154. }
  155. if (($now - $GLOBALS['modeltime']) > $over_time) {
  156. $GLOBALS['modeltime'] = $now;
  157. $GLOBALS['model'] = $this->httpserver->worker_id;
  158. ModelBase::close();
  159. ModelBase::init();
  160. //echo "超时重连数据库-$debugmsg.....\n";
  161. //echo $GLOBALS['modeltime'] . '--' . $GLOBALS['model'] . "\n";
  162. return;
  163. }
  164. //echo "用的旧的连接-$debugmsg...." . $GLOBALS['modeltime'] . '--' . $GLOBALS['model'] . ".\n";
  165. }
  166. public function start()
  167. {
  168. $this->httpserver->start();
  169. }
  170. }