批次處理任務的場景在我們開發中是經常使用的,例如郵件群發,訊息通知,短信,秒殺等等,我們需要將這個耗時的操作放在隊列中來處理,從而大幅度縮短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 App\Jobs; use App\User; use Illuminate\Bus\Queueable; use Illuminate\Queue\SerializesModels; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Foundation\Bus\Dispatchable; use Illuminate\Support\Facades\Mail; 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 App\Http\Controllers; use App\Jobs\SendEmail; use App\User; 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 ,當更新程式碼的時候,需要停止,然後重新啟動,這樣才能把修改的程式碼應用上。
更多Laravel相關技術文章,請造訪Laravel框架入門教學專欄進行學習!
以上是Laravel 佇列發送郵件的詳細內容。更多資訊請關注PHP中文網其他相關文章!