Heim  >  Artikel  >  Backend-Entwicklung  >  Kurze Beschreibung der Yii2-Warteschlange shmilyzxt/yii2-queue

Kurze Beschreibung der Yii2-Warteschlange shmilyzxt/yii2-queue

*文
*文Original
2018-01-03 14:50:371595Durchsuche

Dieser Artikel bietet hauptsächlich einen einfachen Überblick über die Yii2-Warteschlange shmilyzxt/yii2-queue. Freunde in Not können sich darauf beziehen. Ich hoffe, es hilft allen.

shmilyzxt/yii2-queue Einfache Erklärung:

1. Ich verwende die erweiterte Version von yii2 und schaue mir die an Hier wird die MySQL-Warteschlange verwendet. Zuerst schreibe ich das Warteschlangenkonfigurationselement unter das Stammverzeichnis commonconfigmain-local.php und ändere die Datenbankkonfiguration components2 SQL-Dateien in die Datenbank, um eine Warteschlangendatentabelle und eine Datentabelle zu erstellen, wenn die Aufgabe fehlschlägt.composer

2. Gehen Sie zu
vendor\shmilyzxt\yii2-queue\jobs\jobs.sql
vendor\shmilyzxt\yii2-queue\failed\failed.sql
um einen Blick auf den Code zu werfen, pushOn() Die Methode ist in der übergeordneten Klasse

der Klasse

geschrieben:

Yii::$app->queue->pushOn(new SendMial(),['email'=>'49783121@qq.com','title'=>'test','content'=>'email test'],'email');vendorshmilyzxtqueuequeuesDatabaseQueue.php Hinweis: Schauen Sie sich am besten um die yii2-Ereignisklasse hier, http://www.digpage.com/event.DatabaseQueuevendorshmilyzxtqueuebaseQueue.phpÜber das Eingeben der Warteschlange:

Hier arbeiten wir mit der Warteschlangenklassendatei zusammen, um sie anzuzeigen, zu verwandten Funktionen zu springen und zu verarbeiten die Daten und zeichnet sie in der Datenbank auf. (Funktionsrichtung:
//入队列
public function pushOn($job, $data = '', $queue = null)
 {
 //canPush 检查队列是否已达最大任务量
 if ($this->canPush()) { 
  //beforePush 入队列前的事件
  $this->trigger(self::EVENT_BEFORE_PUSH); 
  //入队列
  $ret = $this->push($job, $data, $queue);
  //afterPush 入队列后的事件
  $this->trigger(self::EVENT_AFTER_PUSH);
  return $ret;
 } else {
  throw new \Exception("max jobs number exceed! the max jobs number is {$this->maxJob}");
 }
 }
Gibt schließlich das Ergebnis der Dateneinfügung in die Datenbank zurück. Erfolgreich $ret ist 1.

3. Führen Sie die Befehlsverarbeitungswarteschlange im Hintergrund aus. zum Beispiel:

wobei „Standard“ der Name der oben angezeigten Warteschlange ist, der in „E-Mail“ geändert werden sollte.$this->push($job, $data, $queue);,getQueue()-->createPayload()-->pushToDatabase()),pushOn() start Schauen wir uns nach dem Befehl den Code an: Führen Sie zunächst Folgendes aus:

Controller Bei einer

-Methode folgen wir dem Code in die php ./yii worker/listen default 10 128 3 0 -Methode. Hier wird tatsächlich ständig eine Schleife ausgeführt und die Aufgabe der Operationswarteschlange ausgeführt:

WorkerController Hinweis: ctionListen verwendet Transaktionen um SQL innerhalb der vendorshmilyzxtqueueWorker.php -- listen-Methode auszuführen und eine Instanz von

/**
 * 启用一个队列后台监听任务
 * @param Queue $queue
 * @param string $queueName 监听队列的名称(在pushon的时候把任务推送到哪个队列,则需要监听相应的队列才能获取任务)
 * @param int $attempt 队列任务失败尝试次数,0为不限制
 * @param int $memory 允许使用的最大内存
 * @param int $sleep 每次检测的时间间隔
 */
 public static function listen(Queue $queue, $queueName = 'default', $attempt = 10, $memory = 512, $sleep = 3, $delay = 0){
 while (true){
  try{
  //DatabaseQueue从数据库队列取出一个可用任务(实例),并且更新任务
  $job = $queue->pop($queueName);
  }catch (\Exception $e){
  throw $e;
  continue;
  }
  if($job instanceof Job){
  //判断执行错误的次数是否大于传入的执行次数
  if($attempt > 0 && $job->getAttempts() > $attempt){
   $job->failed();
  }else{
   try{
   //throw new \Exception("test failed");
   $job->execute();
   }catch (\Exception $e){
   //执行失败,判断是否被删除,重新入队
   if (! $job->isDeleted()) {
    $job->release($delay);
   }
   }
  }
  }else{
  self::sleep($sleep);
  }
  if (self::memoryExceeded($memory)) {
  self::stop();
  }
 }
 }

$queue->pop($queueName); zu erstellen. Für: vendorshmilyzxtqueuequeuesDatabaseQueue.php erbt DatabaseJob die übergeordnete Klasse Job Executed, folgen Sie dem Code, um die ausgeführtes Ereignis, vendorshmilyzxtqueuejobsDatabaseJob.php

 //取出一个任务
 public function pop($queue = null)
 {
 $queue = $this->getQueue($queue);
 if (!is_null($this->expire)) {
  //$this->releaseJobsThatHaveBeenReservedTooLong($queue);
 }
 $tran = $this->connector->beginTransaction();
 //判断是否有一个可用的任务需要执行
 if ($job = $this->getNextAvailableJob($queue)) {
  $this->markJobAsReserved($job->id);
  $tran->commit();
  $config = array_merge($this->jobEvent, [
  'class' => 'shmilyzxt\queue\jobs\DatabaseJob',
  'queue' => $queue,
  'job' => $job,
  'queueInstance' => $this,
  ]);
  return \Yii::createObject($config);
 }
 $tran->commit();
 return false;
 }
und schließlich die

der ausgeführten $job->execute()-Klasse erreichen. Hier werden die Objekte und Daten in die Warteschlange verschoben. Dies ist unsere Verarbeitungslogik 🎜>yiibaseComponent trigger

/**
 * 执行任务
 */
public function execute()
{
 $this->trigger(self::EVENT_BEFORE_EXECUTE, new JobEvent(["job" => $this, 'payload' => $this->getPayload()]));//beforeExecute 执行任务之前的一个事件 在JobEvent中并没有什么可执行的代码
 $this->resolveAndFire();//真正执行的任务的方法
}
 /**
 * 真正任务执行方法(调用hander的handle方法)
 * @param array $payload
 * @return void
 */
 protected function resolveAndFire()
 {
  $payload = $this->getPayload();
  $payload = unserialize($payload); //反序列化数据
  $type = $payload['type'];
  $class = $payload['job'];
  if ($type == 'closure' && ($closure = (new Serializer())->unserialize($class[1])) instanceof \Closure) {
   $this->handler = $this->getHander($class[0]);
   $this->handler->closure = $closure;
   $this->handler->handle($this, $payload['data']);
  } else if ($type == 'classMethod') {
   $payload['job'][0]->$payload['job'][1]($this, $payload['data']);
  } else if ($type == 'staticMethod') {
   $payload['job'][0]::$payload['job'][1]($this, $payload['data']);
  } else {//执行的`SendMail`类的`handle($job,$data)`方法
   $this->handler = $this->getHander($class);
   $this->handler->handle($this, $payload['data']);
  }
  //执行完任务后删除
  if (!$this->isDeletedOrReleased()) {
   $this->delete();
  }
 }
Verwandte Empfehlungen:

SendMailhandle($job,$data)

public function handle($job,$data)
 {
  if($job->getAttempts() > 3){
   $this->failed($job);
  }
  $payload = $job->getPayload();
  echo &#39;<pre class="brush:php;toolbar:false">&#39;;print_r($payload);
  //$payload即任务的数据,你拿到任务数据后就可以执行发邮件了
  //TODO 发邮件
 }

Yii2 integriert Xunsou, um einen effizienten Abruf der chinesischen Wortsegmentierung zu erreichen

Yii löst das Problem mit dem Fehler beim Löschen der Verbindungstabelle von DeleteAll

So filtert Yii fehlerhaften Code

Das obige ist der detaillierte Inhalt vonKurze Beschreibung der Yii2-Warteschlange shmilyzxt/yii2-queue. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn