中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何操作Laravel框架中隊列和工作(Queues、Jobs)

發布時間:2021-03-11 16:25:16 來源:億速云 閱讀:230 作者:TREX 欄目:開發技術

這篇文章主要講解了“如何操作Laravel框架中隊列和工作(Queues、Jobs)”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何操作Laravel框架中隊列和工作(Queues、Jobs)”吧!

Laravel 是什么

Laravel 是一套簡潔、優雅的PHP Web開發框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構建一個完美的網絡APP,而且每行代碼都可以簡潔、富于表達力。


在我們的web應用中,經常會遇到這樣的情況:

用戶在進行了某項操作后,我們需要在后臺完成一個耗時且耗費資源的任務,以對應用戶的操作。

通常來說,web應用中的操作都是同步的(synchronous),即用戶的操作可以立即得到回饋。

但是在以上情況下,同步等待操作結果將是災難性的。比如用戶點擊了申請密碼重置郵件,倘若我們讓用戶一直停滯在等待頁面,直至郵件發送成功,那么用戶體驗將非常地不好,因為有時候可能需要很長的時間才能將郵件發送完成。

從另一個角度來說,如果我們服務器處于高負荷的情況,當多個用戶同時請求發送郵件等操作時,我們不希望同時地給服務器增加負荷,否則可能會導致服務器崩潰,造成無法預估的情況。

從以上的討論可以看出,我們需要一種機制,可以非同步地響應用戶操作,并且不會給服務器增加過大的負荷。

那么這樣一種機制就是Queues和Jobs(即隊列和工作)。

如果你系統地學習過計算機科學,那么隊列的概念你應該不陌生。假設我們去銀行辦事,我們拿了一個號,發現前面有8個人在等待,那么我們實際上就處在一個隊列之中,隊列中靠前的人會先被叫到號碼,并且叫號的順序即拿號的順序。這樣的隊列就叫做Queue,采用的是先到先處理的方式,不允許插隊的情況存在。而我們要辦的事情就叫Job。

在Laravel中,我們可以很方便地使用Queues及Jobs來達到我們的目的。首先我們需要先來看一下,Laravel中有哪些Queues。

打開config/queue.php,我們可以看到幾種常見的隊列設置:

return [      
  
  /*      
  |--------------------------------------------------------------------------      
  | Default Queue Connection Name      
  |--------------------------------------------------------------------------      
  |      
  | Laravel's queue API supports an assortment of back-ends via a single      
  | API, giving you convenient access to each back-end using the same      
  | syntax for every one. Here you may define a default connection.      
  |      
  */      
  
  'default' => env('QUEUE_DRIVER', 'sync'),      
  
  /*      
  |--------------------------------------------------------------------------      
  | Queue Connections      
  |--------------------------------------------------------------------------      
  |      
  | Here you may configure the connection information for each server that      
  | is used by your application. A default configuration has been added      
  | for each back-end shipped with Laravel. You are free to add more.      
  |      
  | Drivers: "sync", "database", "beanstalkd", "sqs", "redis", "null"      
  |      
  */      
  
  'connections' => [      
  
    'sync' => [      
      'driver' => 'sync',      
    ],      
  
    'database' => [      
      'driver' => 'database',      
      'table' => 'jobs',      
      'queue' => 'default',      
      'retry_after' => 90,      
    ],      
  
    'beanstalkd' => [      
      'driver' => 'beanstalkd',      
      'host' => 'localhost',      
      'queue' => 'default',      
      'retry_after' => 90,      
    ],      
  
    'sqs' => [      
      'driver' => 'sqs',      
      'key' => env('SQS_KEY', 'your-public-key'),      
      'secret' => env('SQS_SECRET', 'your-secret-key'),      
      'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'),      
      'queue' => env('SQS_QUEUE', 'your-queue-name'),      
      'region' => env('SQS_REGION', 'us-east-1'),      
    ],      
  
    'redis' => [      
      'driver' => 'redis',      
      'connection' => 'default',      
      'queue' => 'default',      
      'retry_after' => 90,      
      'block_for' => null,      
    ],      
  
  ],      
  
  /*      
  |--------------------------------------------------------------------------      
  | Failed Queue Jobs      
  |--------------------------------------------------------------------------      
  |      
  | These options configure the behavior of failed queue job logging so you      
  | can control which database and table are used to store the jobs that      
  | have failed. You may change them to any database / table you wish.      
  |      
  */      
  
  'failed' => [      
    'database' => env('DB_CONNECTION', 'mysql'),      
    'table' => 'failed_jobs',      
  ],      
  
];

在connections中,我們看到sync這個連接。sync是Laravel默認的隊列,代表的就是synchronous,即同步隊列。

今天我們要來看一下,如何使用database,即數據庫來實現異步任務處理。

要使用database來作為隊列的內部實現機制,我們需要建立一張用于儲存Jobs的表:

$ php artisan queue:table     
$ php artisan migrate

以上命令將會在數據庫創建名為jobs的表。

隊列我們有了,那么現在我們來看一下Jobs。Laravel中jobs文件默認位置在app/Jobs文件夾下,我們可以通過make:job這個Artisan命令快速創建我們的job類:

$ php artisan make:job SendEmail

生成的job會實現Illuminate\Contracts\Queue\ShouldQueue這個接口,表明生成的job對象將被推到隊列中進行異步處理。

job類其實很簡單,里面只有一個名為handle的方法,該方法在job被queue處理的時候自動被調用。

在上面的命令中,我們創建了一個名為SendEmail的類:

<?php    
  
namespace App\Jobs;    
  
use App\Email;    
use Illuminate\Bus\Queueable;    
use Illuminate\Queue\SerializesModels;    
use Illuminate\Queue\InteractsWithQueue;    
use Illuminate\Contracts\Queue\ShouldQueue;    
use Illuminate\Foundation\Bus\Dispatchable;    
  
class SendEmail implements ShouldQueue    
{    
  use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;    
  
  protected $email;    
  
  /**    
   * Create a new job instance.    
   *    
   * @param Podcast $podcast    
   * @return void    
   */    
  public function __construct(Email $email)    
  {    
    $this->email = $email;    
  }    
  
  /**    
   * Execute the job.    
   *    
   * @param AudioProcessor $processor    
   * @return void    
   */    
  public function handle()    
  {    
    // Process email and send the email to recipient(s)    
    // 這里我們可以處理我們的郵件并將郵件發送至接收人 
  }    
}

可以看到,我們可以將model傳遞進job的constructor中。Laravel會自動序列化(Serialize)模型的識別信息,在job真正被處理的時候,完整的模型數據才會被從數據庫調用出來。另外,在handle方法中,我們也可以注入我們的依賴dependencies。

好了,現在我們有了job類,可以創建job對象了,那么如何把job添加進隊列呢?

在我們的控制器中,我們可以調用job的dispatch方法來將其添加進隊列中:

<?php  
  
namespace App\Http\Controllers;  
  
use App\Jobs\SendEmail;  
use Illuminate\Http\Request;  
use App\Http\Controllers\Controller;  
use App\Email; 
  
class EmailsController extends Controller  
{  
  /**  
   * Store a new email.  
   *  
   * @param Request $request  
   * @return Response  
   */  
  public function send(Request $request)  
  {  
    // Create email...  
    // 這里我們提取email信息并創建$email, Email是我們自定義的Model 
    $email = Email::create($request->only('sender', 'to', 'content')); 
  
    SendEmail::dispatch($email);  
  }  
}

這樣一來,每當我們的控制器調用send方法時,就會創建一個SendEmail的job在數據庫中。

那么怎么樣調用Queue Worker來處理我們的jobs呢?

在.env文件中,我們將QUEUE_DRIVER=sync改為QUEUE_DRIVER=database。

接下來,我們運行以下Artisan命令:

$ php artisan queue:work

隊列的worker會一直運行,每當有任務被添加進數據庫jobs表中,worker便會自動抓取出任務進行處理。當任務失敗時,worker會重復執行任務,直至最大嘗試次數(默認為255)。我們可以手動設置最大嘗試次數:

$ php artisan queue:work --tries=3

當然,我們也可以手動設置任務的超時(默認90s,在config/queue.php中的retry_after設置):

$ php artisan queue:work --timeout=30

最后,當沒有任務的時候,我們可以設置一個睡眠時間,當worker在睡眠時間時,將不會處理任務:

$ php artisan queue:work --sleep=10

上面的命令意思是每當worker處理完所有任務后,會睡眠10s,然后才會再次檢查任務隊列

本文使用Laravel 5.6進行講解

感謝各位的閱讀,以上就是“如何操作Laravel框架中隊列和工作(Queues、Jobs)”的內容了,經過本文的學習后,相信大家對如何操作Laravel框架中隊列和工作(Queues、Jobs)這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

元阳县| 肃宁县| 宜丰县| 松桃| 县级市| 罗山县| 舞钢市| 伊春市| 孟连| 钦州市| 丰县| 旬邑县| 安庆市| 尼木县| 通化市| 虞城县| 陇南市| 同江市| 上栗县| 开阳县| 南京市| 民权县| 扶沟县| 德兴市| 乐业县| 平顶山市| 灵石县| 文登市| 封丘县| 双鸭山市| 沅陵县| 恩施市| 济南市| 油尖旺区| 高要市| 华容县| 苏尼特左旗| 田阳县| 望奎县| 同德县| 济宁市|