Dalam Laravel, baris gilir ialah alat penting untuk pemprosesan tak segerak Apabila memproses tugas tak segerak, baris gilir membolehkan kami menggunakan sumber pelayan dengan lebih fleksibel dan meningkatkan kebolehskalaan dan prestasi aplikasi. Apabila kami menolak tugas yang memakan masa ke dalam baris gilir, aplikasi akan terus dilaksanakan secara tidak segerak dan kerja latar belakang akan diproses oleh baris gilir. Apabila terdapat tugasan dalam baris gilir yang perlu diproses, kami perlu menggunakan tugasan daripada baris gilir Artikel ini akan memperkenalkan anda kepada cara menggunakan baris gilir Laravel.
Sebelum menggunakan fungsi baris gilir Laravel, kita perlu mengkonfigurasi baris gilir Konfigurasikan parameter berikut dalam fail konfigurasi .env
QUEUE_CONNECTION=redis REDIS_HOST=127.0.0.1 REDIS_PASSWORD=null REDIS_PORT=6379
kepada REDIS_PASSWORD
. Dalam artikel ini, kami menggunakan Redis sebagai pemacu untuk baris gilir Laravel. null
php artisan make:job MyJob
direktori Fail PHP bernama app/Jobs
akan dihasilkan dan kami hanya perlu menambah kod untuk tugasan yang ingin kami selesaikan. MyJob
queue()
$this->dispatch(new MyJob($data));
dispatch()
MyJob::dispatch($data);
dan MyJob
ialah data yang dihantar ke dalam tugasan, yang boleh menjadi tatasusunan atau objek . $data
php artisan queue:work
php artisan queue:work --queue=queue-name --tries=3
ialah nama baris gilir, dan queue-name
ialah bilangan percubaan ralat, iaitu apabila tugasan gagal, proses memproses tugasan akan dicuba semula beberapa kali. Pada masa yang sama, dalam proses memulakan kerja baris gilir, kita juga boleh menentukan kaedah pelaksanaan tugas dalam baris gilir. tries
php artisan queue:listen
ialah ia boleh memantau berbilang nama baris gilir pada masa yang sama, dan kumpulkan tugas baris gilir. php artisan queue:work
supervisor
membolehkan kami memantau tugas baris gilir secara berterusan di latar belakang untuk mengelakkan proses pekerja baris gilir ditamatkan secara tidak dijangka. supervisor
[program:laravel-worker] process_name=%(program_name)s_%(process_num)02d command=php /path/to/artisan queue:work redis --sleep=3 --tries=3 autostart=true autorestart=true user=root numprocs=8 redirect_stderr=true stdout_logfile=/path/to/worker.log
, dengan supervisor
menentukan bilangan proses pekerja baris gilir untuk dibuka. numprocs=8
Atas ialah kandungan terperinci Mari kita bincangkan tentang cara menggunakan tugas baris gilir dalam Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!