Table of Contents
Using experience of queue service (queue) in Laravel 4.2, laravelqueue
Queue in C# If the values ​​in the queue are not repeated
Why is the queue q->rear=(q->rear+1)%queuesize in the data structure not q->rear=(q->rear+1) like You can also
Home Backend Development PHP Tutorial Experience using queue service (queue) in Laravel 4.2, laravelqueue_PHP tutorial

Experience using queue service (queue) in Laravel 4.2, laravelqueue_PHP tutorial

Jul 13, 2016 am 10:15 AM
laravel queue

Using experience of queue service (queue) in Laravel 4.2, laravelqueue

In the past half month, I participated in rewriting a WeChat official account back-end system, using laravel 4.2 for the first time, and laravel’s proud queue service (queue).

Since the entire system involves multi-terminal interaction and a large number of voice transmission and processing services, we found that the response time was too long in some places. The previous system was based on node.js and mongoDB. Since node is inherently asynchronous and has a daemon process, this problem did not occur. However, this rewrite will inevitably introduce asynchronous processes. Queue comes into our sight.

According to this page of "Chinese Documentation" which is almost entirely in English, laravel has just introduced redis as a queue storage in version 4.2, which is very good news. OK, that’s it for the background introduction, let’s talk about the dry stuff below.

The queue service in laravel is no different from other queue services. They are the simplest and most common processes that are most in line with human thinking: there is a place to store queue information, a PHP process writes tasks at runtime, and another A PHP daemon polls the queue for 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.

Laravel's queue configuration file is /app/config/queue.php. In the Default Queue Driver, you can choose from "sync", "beanstalkd", "sqs", "iron", "redis". drive.

1. sync is a synchronization driver for local debugging

2. beanstalkd is a professional queue service driver: http://kr.github.io/beanstalkd/

3. sqs and iron are foreign third-party queue services

4. The last item redis gives us a reason to use redis, so we can migrate all cache services and session services to redis.

0. By the way, don’t use mysql as the session driver. The processing time of 1S is not a dream. Hey, who cares? I’m talking about you, Brother 1S!

The queue service needs to create a new task class. As an independent class, they do not need to inherit the class, because the tasks in the queue are called independently by the PHP daemon when they are executed. Of course, if you want to use other classes If you call it again, there will be no error. Previously, I separated many additional services into a separate folder /app/services, such as input information verification validator, special security verification module, etc. This time the queue classes are located in it.

The use of queue is very simple. Here is a simple example:

Copy code The code is as follows:

use Queue;
Queue::push('CurlJsonQueue', [
'url' => $url,
'json' => $json
]);

This is a standard queue push process. Of course, here I put the CurlJsonQueue class in the services root directory. This directory has been registered by me in the "classmap" of "autoload" in composer.json. It is located in the top-level namespace and can be called directly. If needed, AppOOXX can be written in non-top-level namespaces. Our system requires a lot of interaction with the WeChat server, so we created this class independently.

Copy code The code is as follows:

class CurlJsonQueue extends BaseController{

public function fire($job, $data)
{
$url = $data['url'];
$json = $data['json'];

parent::base_post_curl($url, $json);

$job->delete();
}
}

The default method of this class is fire(), and the parameters are also fixed two $job and $data. Since I encapsulated the post curl module in BaseController, I called it. In addition, there is a small pit here. When I wrote base_post_curl(), I used protected, which caused use BaseController to be invalid and must be inherited.

By executing the above code, a new task is placed in the queue, and laravel starts the daemon process through the following command:

Copy code The code is as follows:

php artisan queue:listen

Then the daemon starts processing the queue. Please adjust the paths of the PHP commands and artisan files in this code yourself.

You may have noticed that the queue system we are going to use uses redis and PHP command line. If you are in a test environment, you can add a boot or even start it manually, but in a production environment, you need more stable tools. To guard these two programs, we use supervisor. For the installation and configuration of supervisor, you can refer to this article: http://blog.segmentfault.com/qianfeng/1190000000532561 Note that there are some pitfalls in the article, please check it yourself. . .

OK, after everything is configured, run the redis and PHP command lines, and the entire system will start to run happily~

Usage experience:

The queue service is super easy to use. The previous interaction process with the app took 6-7S. After asynchronous, it was reduced to less than 2S. This is basically the transmission time and PHP code running time. Time-consuming special operations have been asynchronous. However, the queue service defaults to 1S to open a process to check whether there are any services that can be run in redis. On the Alibaba Cloud server, it can account for about 10% of a single core. The consumption is slightly larger, and the queue processing time is relatively long, because there is no File loading benefits during previous synchronization. However, if there are multiple tasks, the PHP process will be executed continuously, not one every 1 second.

Let’s talk about the pitfalls:

1. Since the queue core class uses a special function, variables without clear types will be stored in json in the form of single-element arrays and then stored in redis. The solution is to add ''. in front of each data to be put in. Since the $url and $json above have already been type-declared in quotes, this step was not performed.

2. If you want to pass the URL to the queue, the system queue class will add two \ before each /. This may have a fatal impact on some special operations. (Just kidding, is it as deadly as the one above!)

Queue in C# If the values ​​in the queue are not repeated

Use Contains (the content you want to check) to make a judgment (return value Boolean type). For example: namespace TestBed
{ public class MainTest
{ public static void Main()
{
int[] numbers = { 1,1,2,3,4,2,5,6, 7};
Queue q = new Queue();
foreach (var item in numbers)
{
if (!q.Contains(item))
{
q.Enqueue(item);
}
}
} }
}

Why is the queue q->rear=(q->rear+1)%queuesize in the data structure not q->rear=(q->rear+1) like You can also

Dear, it’s different. The first expression controls the pointer of the queue to jump in a loop within the range of queuesize, while the second expression pointer will continuously jump backward by the memory distance of one node. It is very possible If it exceeds the effective memory range of the queuesize you defined and occupies unallocated memory, the compiler will report an error. Do you understand? ? ?

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/903478.htmlTechArticleUsing experience of queue service (queue) in Laravel 4.2, laravelqueue In the past half month, I participated in rewriting a WeChat The back-end system of the public account uses laravel 4.2 for the first time, and laravel...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to get the return code when email sending fails in Laravel? How to get the return code when email sending fails in Laravel? Apr 01, 2025 pm 02:45 PM

Method for obtaining the return code when Laravel email sending fails. When using Laravel to develop applications, you often encounter situations where you need to send verification codes. And in reality...

Laravel schedule task is not executed: What should I do if the task is not running after schedule: run command? Laravel schedule task is not executed: What should I do if the task is not running after schedule: run command? Mar 31, 2025 pm 11:24 PM

Laravel schedule task run unresponsive troubleshooting When using Laravel's schedule task scheduling, many developers will encounter this problem: schedule:run...

In Laravel, how to deal with the situation where verification codes are failed to be sent by email? In Laravel, how to deal with the situation where verification codes are failed to be sent by email? Mar 31, 2025 pm 11:48 PM

The method of handling Laravel's email failure to send verification code is to use Laravel...

How to implement the custom table function of clicking to add data in dcat admin? How to implement the custom table function of clicking to add data in dcat admin? Apr 01, 2025 am 07:09 AM

How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

Laravel Redis connection sharing: Why does the select method affect other connections? Laravel Redis connection sharing: Why does the select method affect other connections? Apr 01, 2025 am 07:45 AM

The impact of sharing of Redis connections in Laravel framework and select methods When using Laravel framework and Redis, developers may encounter a problem: through configuration...

Laravel multi-tenant extension stancl/tenancy: How to customize the host address of a tenant database connection? Laravel multi-tenant extension stancl/tenancy: How to customize the host address of a tenant database connection? Apr 01, 2025 am 09:09 AM

Custom tenant database connection in Laravel multi-tenant extension package stancl/tenancy When building multi-tenant applications using Laravel multi-tenant extension package stancl/tenancy,...

Laravel Eloquent ORM in Bangla partial model search) Laravel Eloquent ORM in Bangla partial model search) Apr 08, 2025 pm 02:06 PM

LaravelEloquent Model Retrieval: Easily obtaining database data EloquentORM provides a concise and easy-to-understand way to operate the database. This article will introduce various Eloquent model search techniques in detail to help you obtain data from the database efficiently. 1. Get all records. Use the all() method to get all records in the database table: useApp\Models\Post;$posts=Post::all(); This will return a collection. You can access data using foreach loop or other collection methods: foreach($postsas$post){echo$post->

Laravel's geospatial: Optimization of interactive maps and large amounts of data Laravel's geospatial: Optimization of interactive maps and large amounts of data Apr 08, 2025 pm 12:24 PM

Efficiently process 7 million records and create interactive maps with geospatial technology. This article explores how to efficiently process over 7 million records using Laravel and MySQL and convert them into interactive map visualizations. Initial challenge project requirements: Extract valuable insights using 7 million records in MySQL database. Many people first consider programming languages, but ignore the database itself: Can it meet the needs? Is data migration or structural adjustment required? Can MySQL withstand such a large data load? Preliminary analysis: Key filters and properties need to be identified. After analysis, it was found that only a few attributes were related to the solution. We verified the feasibility of the filter and set some restrictions to optimize the search. Map search based on city

See all articles