🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
~~~ <?php /** * @Author: 陈静 * @Date: 2018/04/26 22:27:00 * @Description: */ namespace app\worker\controller; use app\base\controller\Redis; use think\Config; use think\Db; use think\Exception; use think\Log; abstract class WorkerHookBase { protected $listName; protected $redis; protected $workList; protected $workerName; public static $instance; protected $connect =[] ; protected $saveLog=false; protected $tableName = "mk_log_service_queue"; protected $error; /** * Base constructor. * @param array $options */ public function __construct($options=[]) { $this->redis = $this->redis(); $this->workList = "worker_list"; $this->workerName = get_called_class(); $this->listName = md5($this->workerName); $this->_initialize(); } public function _initialize(){ } public function run(&$prams,$options){ self::add( $prams,$options); } abstract protected function runHandle ($data); /** * @title redis * @description redis加载自定义Redis类 * User: Mikkle * QQ:776329498 * @param array $options */ protected static function redis(){ $options = empty($options) ? $redis = Config::get("redis") : $options; return Redis::instance($options); } /** * @title runWorker * @description 标注命令行执行此任务 * User: Mikkle * QQ:776329498 * @param string $handleName */ public function runWorker($handleName="workRunFunction"){ $this->redis->hset($this->workList,$this->workerName,$handleName); } /** * 标注命令行清除此任务 * Power: Mikkle * Email:776329498@qq.com */ public function clearWorker(){ $this->redis->hdel($this->workList,$this->workerName); } /** * Power: Mikkle * Email:776329498@qq.com * @param array $options * @return static */ static public function instance($options=[]){ if (isset(static::$instance)){ return static::$instance; }else{ return new static($options); } } /** * * 快速添加模版消息任务 * * 当命令行未运行 直接执行 * description add * User: Mikkle * QQ:776329498 * @param $data * @param array $options * @param string $handleName * @return bool */ static public function add($data,$options=[],$handleName="workRunFunction"){ try{ $data=json_encode($data); $instance = static::instance($options); switch (true){ case (self::checkCommandRun()): $instance->redis->lpush($instance->listName,$data); $instance->runWorker($handleName); Log::notice("Command service start work!!"); break; default: Log::notice("Command service No away!!"); $instance->runHandle($data); } return true; }catch (Exception $e){ Log::error($e->getMessage()); return false; } } /** * 命令行执行的方法 * Power: Mikkle * Email:776329498@qq.com */ static public function workRunFunction(){ $instance = static::instance(); try{ $i = 0; while(true){ $redisData= $instance->redis->rpop($instance->listName); $data = json_decode($redisData,true); if ($data){ $result = $instance->runHandle($data); if ($instance->saveLog){ $instance->saveRunLog($result,$data); } }else{ $instance->clearWorker(); break; } $i++; sleep(1); } echo "执行了{$i}次任务".PHP_EOL; }catch (Exception $e){ Log::error($e->getMessage()); echo ($e->getMessage()); } } /** * 检测命令行是否执行中 * Power: Mikkle * Email:776329498@qq.com * @return bool */ static public function checkCommandRun(){ return self::redis()->get("command") ? true :false; } public function getError(){ if (is_array($this->error )){ return json_encode( $this->error ); } return $this->error; } /* * 检查是注重某些值是非为空 */ protected function checkArrayValueEmpty($array,$value,$error=true){ switch (true){ case (empty($array)||!is_array($array)): if ($error==true){ $this->addError("要检测的数据不存在或者非数组"); } return false; break; case (is_array($value)): foreach ($value as $item){ if (!isset($array[$item]) || (empty($array[$item]) && $array[$item]!==0)){ if ($error==true) { $this->addError("要检测的数组数据有不存在键值{$item}"); } return false; } } break; case (is_string($value)): if (!isset($array[$value]) || empty($array[$value] && $array[$value]!==0)){ if ($error==true) { $this->addError("要检测的数组数据有不存在键值{$value}"); } return false; } break; default: } return true; } public function addError($error){ $this->error = is_string($error) ? $error : json_encode($error); } protected function saveRunLog($result,$data){ try{ $operateData = [ "class" => $this->workerName, "args" => json_encode($data), "result"=> $result ? "true":"false", "error" => $this->error ? $this->getError() : null, "time" => time(), ]; Db::connect($this->connect)->table($this->tableName)->insert($operateData); }catch (Exception $e){ Log::error($e->getMessage()); } } } ~~~