0

次のような電子メールジョブをセットアップしました。

dispatch(new NewUserEmail($newUser->email, $newUser->username));

私のジョブファイルは次のようになります。

<?php

namespace App\Jobs;

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\Log;
use App\Mail\NewUser;
use Mail;

class NewUserEmail implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

    protected $email;
    protected $username;
    public $tries = 5;

    /**
     * Create a new job instance.
     */
    public function __construct($email, $username)
    {
        $this->email = $email;
        $this->username = $username;
    }

    /**
     * Execute the job.
     */
    public function handle()
    {
        try {
            Mail::to($this->email)->send(new NewUsedfr($this->username));
        } catch (\Exception $e) {
            Log::error('NewUserEmailJob failed NewUser');
            Log::error('NewUserEmailJob log: '.$e);
            throw new \Exception($e);
        }
    }
}

ただし、意図的にメールファイルのスペルを間違えました。NewUsedfrこれはNewUser 、例外をトリガーするためです。

しかし、ジョブを実行すると、Horizo​​n でジョブが失敗としてマークされずに終了することがわかります。望遠鏡で見ると、ログタブに例外やエラーが表示されません..

そのため、手動で storage/logs フォルダーを調べたところ、次の行が表示されました。

Class 'App\Jobs\NewUsedfr' not found {"exception":"[object]

では、なぜ私の仕事は地平線で失敗せず、望遠鏡で上記のエラーが表示されないのですか? 望遠鏡がストレージ/ログフォルダーからのエラーを表示しないのは少し奇妙に思えます

4

1 に答える 1