Пример #1
0
 /**
  * 处理受到的数据
  * @param TcpConnection $connection
  * @return void
  */
 public function onConnect($connection)
 {
     $socket = $connection->getSocket();
     $t_socket = new TSocket();
     $t_socket->setHandle($socket);
     $transport_name = '\\Thrift\\Transport\\' . $this->thriftTransport;
     $transport = new $transport_name($t_socket);
     $protocol_name = '\\Thrift\\Protocol\\' . $this->thriftProtocol;
     $protocol = new $protocol_name($transport);
     // 执行处理
     try {
         // 先初始化一个
         $protocol->fname == 'none';
         // 统计开始时间
         StatisticClient::tick();
         // 业务处理
         $this->processor->process($protocol, $protocol);
         StatisticClient::report($this->name, $protocol->fname, 1, 0, '', $this->statisticAddress);
     } catch (\Exception $e) {
         StatisticClient::report($this->name, $protocol->fname, 0, $e->getCode(), $e, $this->statisticAddress);
         ThriftWorker::log('CODE:' . $e->getCode() . ' MESSAGE:' . $e->getMessage() . "\n" . $e->getTraceAsString() . "\nCLIENT_IP:" . $connection->getRemoteIp() . "\n");
         $connection->send($e->getMessage());
     }
 }