| <?php | 
| /** | 
|  * 远程调度器 Task_Runner_Remote | 
|  *  | 
|  * - 通过远程请求接口实现任务调度 | 
|  *  | 
|  * @author dogstar <chanzonghuang@gmail.com> 20150516 | 
|  */ | 
|   | 
| class Task_Runner_Remote extends Task_Runner { | 
|   | 
|     /** | 
|      * @var Task_Runner_Remote_Connector 远程接口连接器实例 | 
|      */ | 
|     protected $contector; | 
|   | 
|     /** | 
|      * @var int $timeoutMS 接口超时(单位:毫秒) | 
|      */ | 
|     protected $timeoutMS; | 
|   | 
|     /** | 
|      * @var int 默认最大接口超时 | 
|      */ | 
|     const MAX_TIMEOUT_MS = 3000; | 
|   | 
|     public function __construct(Task_MQ $mq, $step = 10, Task_Runner_Remote_Connector $contector = NULL) { | 
|         $config = DI()->config->get('app.Task.runner.remote'); | 
|   | 
|         if ($contector === NULL) { | 
|             if (empty($config['host'])) { | 
|                 throw new PhalApi_Exception_InternalServerError(T('task miss api host for')); | 
|             } | 
|             $contector = new Task_Runner_Remote_Connector_Http($config); | 
|         } | 
|   | 
|         $this->contector = $contector; | 
|         $this->timeoutMS = isset($config['timeoutMS']) ? intval($config['timeoutMS']) : self::MAX_TIMEOUT_MS; | 
|   | 
|         parent::__construct($mq, $step); | 
|     } | 
|   | 
|     protected function youGo($service, $params) { | 
|         $rs = $this->contector->request($service, $params, $this->timeoutMS); | 
|   | 
|         if ($this->contector->getRet() == 404) { | 
|             throw PhalApi_Exception_InternalServerError('task request api time out', | 
|                 array('url' => $this->contector->getUrl())); | 
|         } | 
|   | 
|         $isOk = $this->contector->getRet() == 200 ? TRUE : FALSE; | 
|   | 
|         if (!$isOk) { | 
|             DI()->logger->debug('task remote request not ok',  | 
|                 array('url' => $this->contector->getUrl(), 'ret' => $this->contector->getRet(), 'msg' => $this->contector->getMsg())); | 
|         } | 
|   | 
|         return $isOk; | 
|     } | 
| } |