In laravel, a queue is a linear table with restricted operations. It only allows deletion operations at the front end of the table (queue head), and insertion operations at the back end of the table (queue tail); Through queues, developers can postpone the processing of time-consuming tasks, which can greatly improve the response speed of web requests.
The operating environment of this tutorial: Windows 7 system, Laravel 6 version, Dell G3 computer.
1. What is a queue
Queue It is a linear table with restricted operations. The special feature is that it only allows deletion operations at the front end of the table and insertion operations at the back end of the table. The end that performs the insertion operation is called the tail of the queue, and the end that performs the deletion operation is called the head of the queue.
With queues, you can postpone the processing of time-consuming tasks (such as sending emails) until later. Delaying these time-consuming tasks can greatly improve web request response speed.
2. Advantages
Decoupling: The message queue can decouple the system and improve the response speed. Functions are aggregated inward and open to the outside;
Asynchronous: Message queue can strip off the asynchronous functions of the system, reduce functional coupling, and improve development efficiency;
Peak clipping: The message queue can clip peak and flow to ensure stable operation of downstream consumers;
3. Configuration
The queue configuration file is stored in config/queue.php. In this file, you can find the connection configuration for each queue driver included in the framework, which includes database, Beanstalkd, Amazon SQS, Redis, and a synchronization driver (sync - for local use).
Redis is used as the driver here, and Redis and related extensions need to be installed.
4. Task
We need to put something into the queue, we can call it a task. Creating tasks in the Laravel framework provides us with the following commands:
php artisan make:job TestJob
TestJob.php
namespace App\Jobs;use Illuminate\Bus\Queueable;use Illuminate\Contracts\Queue\ShouldBeUnique;use Illuminate\Contracts\Queue\ShouldQueue;use Illuminate\Foundation\Bus\Dispatchable;use Illuminate\Queue\InteractsWithQueue;use Illuminate\Queue\SerializesModels;use Illuminate\Support\Facades\DB;use Symfony\Polyfill\Intl\Idn\Info;class TestJob implements ShouldQueue{ use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; /** * Create a new job instance. * * @return void */ public function __construct() { // } /** * Execute the job. * * @return void */ public function handle() {// \Log::info('hhh'); DB::connection('test') ->table('master') ->insert([ 'name'=>'小白', 'email'=>'123@qq.com' ]); }}
5. Distribution
Once you write a task class, you can dispatch it using the dispatch method of the task itself. The parameters passed to the dispatch method will be passed to the task's constructor.
onQueue: Specified queue;
onConnection: Specified connection;
delay: Delay queue;
dispatchNow: Synchronous scheduling;
#在路由中简单调用 Route::get('queue',function(){ \App\Jobs\TestJob::dispatch(); // \App\Jobs\TestJob::dispatch()->onQueue('qq'); });
Run two This route can be seen to generate a queue named qq. Later we will consume the queue
6. Queue consumption
Laravel has a queue processor to process newly pushed tasks into the queue. Start the queue processor with the Artisan command queue:work. It should be noted that once the queue:work command is started, it will keep running until it is manually stopped or you close your terminal:
php artisan queue:work
php artisan queue: work --once Add parameters and consume the specified queue
#消费qq队列 php artisan queue:work --queue=qq
You can see that two new pieces of data have been added to the database, and the data in redis has been consumed
We execute routing again
7, event queue
Queue is usually used to handle delayed tasks, and events are processed by business logic. Event triggers in Laravel are distributed to queues for asynchronous business processing, so that you can quickly respond without having to wait for the execution results in real time before giving prompt messages to users.
If we need to store the business in the event into the queue, we do not need to re-distribute the queue. We can directly implement the Illuminate\Contracts\Queue\ShouldQueue interface in the corresponding listener.
Create events and listeners
php artisan make:event TestEvent php artisan make:listener TestListener
Register in app\providers\EventServiceProvider.php
TestListener.php
namespace App\Listeners; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Support\Facades\DB; class TestListener implements ShouldQueue { /** * Create the event listener. * * @return void */ public function __construct() { // } /** * Handle the event. * * @param object $event * @return void */ public function handle() { DB::connection('test') ->table('master') ->insert([ 'name'=>'小黑', 'email'=>'234@qq.com' ]); } }
Modify routing
Route::get('queue',function(){ //\App\Jobs\TestJob::dispatch(); //指定队列名称 //\App\Jobs\TestJob::dispatch()->onQueue('qq'); return event(new \App\Events\TestEvent()); });
Run routing
Consumption queue
php artisan queue:work
【Related recommendations: laravel video tutorial】
The above is the detailed content of What is laravel queue. For more information, please follow other related articles on the PHP Chinese website!