


Tutorial on the most basic operation of using Queue in Laravel
Laravel queue service provides a unified API for various background queues. The following article mainly introduces you to the most basic operation tutorial on using Queue in Laravel. The article introduces it in detail through sample code. Friends who need it You can use it as a reference, let’s take a look below.
Preface
The queue service in laravel is no different from other queue services. They are the simplest and most common ones that are most in line with human thinking. The process: There is a place to store queue information, a PHP process writes tasks when running, and another PHP daemon process polls the queue information, executes and deletes tasks that meet the execution requirements. Since PHP is a URL-driven synchronous language and inherently blocking, it is not surprising that Laravel provides a daemon tool to query and execute queue information.
It was the first time I came into contact with Laravel’s queue in the past two days, and it took a long time. . . After all the hard work, I still feel that I don’t know how to use Laravel. The documentation is relatively simple and summarized, and it’s a bit difficult to read the source code (but reading the source code and slowly debugging and verifying it is still the most reliable).
The following is a simple demo of mine, which only uses the most basic operations of the queue. More advanced operations require more time:)
Like me, there are some queues for getting started with Laravel. Students who are in difficulty can communicate with each other.
Configuration
Add Redis package
In composer.json Add "predis/predis": "~1.0" to the require section, and then composer up to update it.
database.php
Configure the redis database part in the database.php configuration file. There is a default connection by default. Just use this: )
According to the configuration items required in this default connection, edit the .env configuration file and fill in the REDIS_HOST, REDIS_PASSWORD, and REDIS_PORT with the corresponding values of Redis in your own server.
queue.php
First you need to configure QUEUE_DRIVER in .env. Because you plan to use Redis now, you configure it to redis.
Then configure the redis connection in the connections section of queue.php, where the value corresponding to connection is the default connection of redis in database.php.
Task class
The next step is to write the actual operation class. Laravel provides the artisan command to simplify the creation of task classes:
php artisan make:job Demo
The Jobs directory will be generated in the app directory, which already has the Demo.php task class.
Lumen does not have this artisan command, but it is very convenient. By default, there will be an ExampleJob.php already written, just copy it and change the name.
First write a simple log output test, in the handle method:
Log::info('Hello, queue');
Issuing tasks
Now write an entry function to push the task to the queue. Use the auxiliary function dispatch():
Use the following method in Laravel:
Demo::dispatch();
Use the following method in Lumen:
dispatch(new Demo);
Open the queue
If everything goes well, this is the last step. Execute in the command line:
php artisan queue:listen --queue=default
It will monitor the queue and output simple execution conditions, such as:
[2017-11-07 02:12:47] Processing: App\Jobs\Demo [2017-11-07 02:12:47] Processed: App\Jobs\Demo
After there are no problems, you can let this queue script execute in the background:
php artisan queue:work --daemon --quiet --queue=default 1>> /dev/null 2>&1
Advanced:)
When pushing to the queue, there is usually a need to pass parameters, so how do you pass them here?
Parameter passing
Passing in
The method of passing parameters in the entry function is as follows:
The following method is used in Laravel:
$param = 'Stephen'; Demo::dispatch($param);
The following method is used in Lumen:
$param = 'Stephen'; dispatch(new Demo($param));
Receive
The method of receiving parameters in the task class is as follows:
protected $param; /** * Create a new job instance. * * @return void */ public function __construct($param) { $this->param = $param; } /** * Execute the job. * * @return void */ public function handle() { Log::info('Hello, ' . $this->param); }
This is the first attempt. There are many advanced usages, such as delayed distribution, error handling, priority, failure handling, etc. I will continue to write in the future:)
Multiple Queues
This is an issue that must be taken into consideration. It is impossible for me to put all tasks in a queue called default, which makes it difficult to manage the queue.
To specify different queues, it is very simple. Just follow the onQueue() method immediately after dispatch():
Demo::dispatch()->onQueue('emails');
No, I don't seem to have defined this queue called emails. Well, naturally we need to make some changes. The redis configuration queue in the queue.php configuration file is changed from default to {default}. The effect of this is that the name of the queue can be obtained dynamically from runtime instead of being hard-coded. .
If you use the Lumen framework, you will get an error if you write directly like this: Call to a member function onQueue() on string.
原因在于 Lumen 的 Job 基类中并没有使用 Illuminate\Foundation\Bus\Dispatchable 这个 trait,而是直接使用 Illuminate\Bus\Queueable 中的 onQueue() 方法。
那么现在就很清楚了,我们的 Job 类使用了 Illuminate\Bus\Queueable 这个 trait,所以需要在 Job 类上调用这个 onQueue() 方法。
$job = new XXXJob(); dispatch($job->onQueue('queue-name'));
当我们在开启队列的时候:
php artisan queue:work --queue=emails
这里指定的队列名 emails 和 dispatch 时指定的队列名保持一致即可。
总结
您可能感兴趣的文章:
The above is the detailed content of Tutorial on the most basic operation of using Queue in Laravel. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The latest versions of Laravel 9 and CodeIgniter 4 provide updated features and improvements. Laravel9 adopts MVC architecture and provides functions such as database migration, authentication and template engine. CodeIgniter4 uses HMVC architecture to provide routing, ORM and caching. In terms of performance, Laravel9's service provider-based design pattern and CodeIgniter4's lightweight framework give it excellent performance. In practical applications, Laravel9 is suitable for complex projects that require flexibility and powerful functions, while CodeIgniter4 is suitable for rapid development and small applications.

Compare the data processing capabilities of Laravel and CodeIgniter: ORM: Laravel uses EloquentORM, which provides class-object relational mapping, while CodeIgniter uses ActiveRecord to represent the database model as a subclass of PHP classes. Query builder: Laravel has a flexible chained query API, while CodeIgniter’s query builder is simpler and array-based. Data validation: Laravel provides a Validator class that supports custom validation rules, while CodeIgniter has less built-in validation functions and requires manual coding of custom rules. Practical case: User registration example shows Lar

For beginners, CodeIgniter has a gentler learning curve and fewer features, but covers basic needs. Laravel offers a wider feature set but has a slightly steeper learning curve. In terms of performance, both Laravel and CodeIgniter perform well. Laravel has more extensive documentation and active community support, while CodeIgniter is simpler, lightweight, and has strong security features. In the practical case of building a blogging application, Laravel's EloquentORM simplifies data manipulation, while CodeIgniter requires more manual configuration.

When choosing a framework for large projects, Laravel and CodeIgniter each have their own advantages. Laravel is designed for enterprise-level applications, offering modular design, dependency injection, and a powerful feature set. CodeIgniter is a lightweight framework more suitable for small to medium-sized projects, emphasizing speed and ease of use. For large projects with complex requirements and a large number of users, Laravel's power and scalability are more suitable. For simple projects or situations with limited resources, CodeIgniter's lightweight and rapid development capabilities are more ideal.

BitgetLaunchpool is a dynamic platform designed for all cryptocurrency enthusiasts. BitgetLaunchpool stands out with its unique offering. Here, you can stake your tokens to unlock more rewards, including airdrops, high returns, and a generous prize pool exclusive to early participants. What is BitgetLaunchpool? BitgetLaunchpool is a cryptocurrency platform where tokens can be staked and earned with user-friendly terms and conditions. By investing BGB or other tokens in Launchpool, users have the opportunity to receive free airdrops, earnings and participate in generous bonus pools. The income from pledged assets is calculated within T+1 hours, and the rewards are based on

Laravel - Artisan Commands - Laravel 5.7 comes with new way of treating and testing new commands. It includes a new feature of testing artisan commands and the demonstration is mentioned below ?

For small projects, Laravel is suitable for larger projects that require strong functionality and security. CodeIgniter is suitable for very small projects that require lightweight and ease of use.

Comparing Laravel's Blade and CodeIgniter's Twig template engine, choose based on project needs and personal preferences: Blade is based on MVC syntax, which encourages good code organization and template inheritance. Twig is a third-party library that provides flexible syntax, powerful filters, extended support, and security sandboxing.
