Laravel 佇列傳送郵件

Joonas發表於2019-02-16

批量處理任務的場景在我們開發中是經常使用的,比如郵件群發,訊息通知,簡訊,秒殺等等,我們需要將這個耗時的操作放在佇列中來處理,從而大幅度縮短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 ,當更新程式碼的時候,需要停止,然後重新啟動,這樣才能把修改的程式碼應用上。

相關文章