Laravel 隊列發送郵件
批量處理任務的場景在我們開發中是經常使用的,比如郵件群發,消息通知,短信,秒殺等等,我們需要將這個耗時的操作放在隊列中來處理,從而大幅度縮短Web請求和相應的時間。下面講解下Laravel中隊列的使用
配置文件 config/queue.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
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方法手動分發任務,方法里傳一個任務類的實例
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 ,當更新代碼的時候,需要停止,然后重新啟動,這樣才能把修改的代碼應用上。
https://segmentfault.com/a/1190000010755314
Laravel
版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。