批量處理任務的場景在我們開發中是經常使用的,比如郵件群發,訊息通知,簡訊,秒殺等等,我們需要將這個耗時的操作放在佇列中來處理,從而大幅度縮短Web請求和相應的時間。下面講解下Laravel中佇列的使用
-
配置檔案 config/queue.php
<?php
return [
`default` => env(`QUEUE_DRIVER`, `sync`),
`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` => `your-public-key`,
`secret` => `your-secret-key`,
`prefix` => `https://sqs.us-east-1.amazonaws.com/your-account-id`,
`queue` => `your-queue-name`,
`region` => `us-east-1`,
],
`redis` => [
`driver` => `redis`,
`connection` => `default`,
`queue` => `default`,
`retry_after` => 90,
],
],
`failed` => [
`database` => env(`DB_CONNECTION`, `mysql`),
`table` => `failed_jobs`,
],
];
配置檔案預設使用的是同步驅動sync,每一種佇列驅動的配置都可以在該檔案中找到, 包括資料庫, Beanstalkd, Amazon SQS, Redis。 其中還包含了一個null佇列驅動用於那些放棄佇列的任務。failed配置項用於配置失敗佇列任務存放的資料庫及資料表。 接下來我們需要建立一個佇列任務類。具體配置可以參考文件 佇列驅動配置
-
建立佇列任務類,之後會在app/Jobs目錄下生成一個SendEmail.php的檔案
php artisan make:job SendEmail
<?php
namespace AppJobs;
use AppUser;
use IlluminateBusQueueable;
use IlluminateQueueSerializesModels;
use IlluminateQueueInteractsWithQueue;
use IlluminateContractsQueueShouldQueue;
use IlluminateFoundationBusDispatchable;
use IlluminateSupportFacadesMail;
class SendEmail implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
protected $user;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct(User $user)
{
$this->user = $user;
}
/**
* 執行佇列的方法 比如傳送郵件
*
* @return void
*/
public function handle()
{
$user = $this->user;
Mail::raw(`這裡填寫郵件的內容`,function ($message){
// 發件人(你自己的郵箱和名稱)
$message->from(`your_email@163.com`, `yourname`);
// 收件人的郵箱地址
$message->to($this->user);
// 郵件主題
$message->subject(`佇列傳送郵件`);
});
}
}
任務類建立完之後到控制器 把資料加入到佇列
-
建立傳送訊息的控制器 使用dispatch方法手動分發任務,方法裡傳一個任務類的例項
<?php
namespace AppHttpControllers;
use AppJobsSendEmail;
use AppUser;
class MessageController extends Controller
{
public function index()
{
$user = User::find(1);
$this->dispatch(new SendEmail($user));
}
}
-
然後訪問瀏覽器,執行專案把任務推送到佇列中。然後使用Artisan命令,執行佇列裡的任務
php artisan queue:
queue:work 預設只執行一次佇列請求, 當請求執行完成後就終止;
queue:listen 監聽佇列請求,只要執行著,就能一直接受請求,除非手動終止;
queue:work --daemon同listen一樣,不同的是work不需要再次載入框架,直接執行任務,一般推薦使用這個來處理佇列監聽。
注:使用 queue:work --daemon ,當更新程式碼的時候,需要停止,然後重新啟動,這樣才能把修改的程式碼應用上。