HttpServerDataInf.php 7.1 KB

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