laravel自定义使用方法(Laravel使用Queue队列的技巧汇总)
laravel自定义使用方法
Laravel使用Queue队列的技巧汇总前言
Laravel 队列为不同的后台队列服务提供统一的 API,例如 Beanstalk,Amazon SQS,Redis,甚至其他基于关系型数据库的队列。队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短 Web 请求和相应的时间。
队列配置文件存放在 config/queue.php 。每一种队列驱动的配置都可以在该文件中找到,包括数据库,Beanstalkd ,Amazon SQS,Redis,以及同步(本地使用)驱动。其中还包含了一个 null 队列驱动用于那些放弃队列的任务
为什么使用队列?
一般来说使用队列是为了:
异步
重试
也许你还有其他的理由使用队列,但是这应该是最基本的两个原因。
什么情况使用队列?
了解了为什么使用队列,那么一般有这么几类任务使用队列:
耗时比较久的,比如上传一个文件后进行一些格式的转化等。
需要保证送达率的,比如发送短信,因为要调用别人的 api,总会有几率失败,那么为了保证送达,重试就必不可少了。
使用队列的时候一定要想明白一个问题,这个任务到底是不是可以异步,如果因为异步会导致问题,那么就要放弃使用队列。
驱动的必要设置
database.php
在 database.php 配置文件中对 redis 数据库部分进行配置,默认有一个 default 连接,就用这个好了:)
根据这个默认连接中需要的配置项,编辑 .env 配置文件,将其中的 REDIS_HOST、REDIS_PASSWORD、REDIS_PORT 填写成自己服务器中 Redis 的相应值。
queue.php
首先需要去 .env 中配置 QUEUE_DRIVER,因为现在打算用 Redis,所以配置成 redis。
接着配置 queue.php 里 connections 部分的 redis 连接,其中 connection 对应的值就是 database.php 中 redis 的那个 default 连接。
数据库
要使用 database 这个队列驱动的话,你需要创建一个数据表来存储任务。你可以用 queue:table 这个 Artisan
|
php artisan queue:table |
处理失败的任务
有时候你队列中的任务会失败。不要担心,本来事情就不会一帆风顺。
Laravel 内置了一个方便的方式来指定任务重试的最大次数。当任务超出这个重试次数后,它就会被插入到 failed_jobs 数据表里面。要创建 failed_jobs 表的迁移文件,你可以用 queue:failed-table 命令,接着使用 migrate Artisan 命令生成 failed_jobs 表:
|
php artisan queue:failed-table |
命令来创建这个数据表的迁移。当迁移创建好以后,就可以用 migrate 这条命令来创建数据表:
|
php artisan migrate |
执行命令讲解
|
php artisan queue:work --daemon --quiet --queue= default --delay=3 --sleep=3 --tries=3 |
|
--daemon |
The queue:work Artisan command includes a --daemon option for forcing the queue worker to continue processing jobs without ever re-booting the framework. This results in a significant reduction of CPU usage when compared to the queue:listen command
总体来说,在 supervisor 中一般要加这个 option,可以节省 CPU 使用。
|
--quiet |
不输出任何内容
|
--delay=3 |
一个任务失败后,延迟多长时间后再重试,单位是秒。这个值的设定我个人建议不要太短,因为一个任务失败(比如网络原因),重试时间太短可能会出现连续失败的情况。
|
--sleep=3 |
去 Redis 中拿任务的时候,发现没有任务,休息多长时间,单位是秒。这个值的设定要看你的任务是否紧急,如果是那种非常紧急的任务,不能等待太长时间。
|
--tries=3 |
定义失败任务最多重试次数。这个值的设定根据任务的重要程度来确定,一般 3 次比较适合。
创建任务
生成任务类
在你的应用程序中,队列的任务类都默认放在 app/Jobs 目录下。如果这个目录不存在,那当你运行 make:job Artisan 命令时目录就会被自动创建。你可以用以下的 Artisan 命令来生成一个新的队列任务:
|
php artisan make:job Demo |
生成的类实现了 Illuminate\Contracts\Queue\ShouldQueue 接口,这意味着这个任务将会被推送到队列中,而不是同步执行。
|
<?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; class Demo implements ShouldQueue { use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; public $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); } } |
控制器代码
|
public function queue_demo() { $num = rand(1,999999999); // 这个任务将被分发到默认队列... DemoJob::dispatch( $num ); } |
开启队列
|
php artisan queue:work --queue= default |
由于是本地,需要打开监听,当访问到接口时,就会触发队列中的任务
线上的话需要用到supervisor的配置
Supervisor 配置
安装 Supervisor
Supervisor 是一个 Linux 操作系统上的进程监控软件,它会在 queue:listen 或 queue:work 命令发生失败后自动重启它们。在 Ubuntu 安装 Supervisor,可以用以下命令:
|
sudo apt-get install supervisor |
{tip} 如果自己手动配置 Supervisor 听起来有点难以应付,可以考虑使用 Laravel Forge,它能给你的 Laravel 项目自动安装与配置 Supervisor。
配置 Supervisor
Supervisor 的配置文件一般是放在 /etc/supervisor/conf.d 目录下。在这个目录中你可以创建任意数量的配置文件来要求 Supervisor 怎样监控你的进程。例如我们创建一个 laravel-worker.conf 来启动与监控一个 queue:work 进程:
|
[program:laravel-worker] process_name=%(program_name)s_%(process_num)02d command=php /home/forge/app.com/artisan queue:work sqs --sleep=3 --tries=3 autostart=true autorestart=true user=forge numprocs=8 redirect_stderr=true stdout_logfile=/home/forge/app.com/worker.log |
这个例子里的 numprocs 命令会要求 Supervisor 运行并监控 8 个 queue:work 进程,并且在它们运行失败后重新启动。当然,你必须更改 command 命令的 queue:work sqs ,以显示你所选择的队列驱动。
启动 Supervisor 当这个配置文件被创建后,你需要更新 Supervisor 的配置,并用以下命令来启动该进程:
|
sudo supervisorctl reread sudo supervisorctl update sudo supervisorctl start laravel-worker:* |
更多有关 Supervisor 的设置与使用,请参考 Supervisor 官方文档
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对开心学习网的支持。
原文链接:https://juejin.im/post/5d5fa2bd5188257a78382596
- laravel多线程处理请求(Laravel 6 将新增为指定队列任务设置中间件的功能)
- rabbitmq延迟队列原理(Rabbitmq heartbea心跳检测机制原理解析)
- laravel队列是如何触发的(laravel 事件/监听器实例代码)
- laravel 队列导入数据(laravel框架查询数据集转为数组的两种方法)
- laravel队列是如何触发的(laravel使用Faker数据填充的实现方法)
- python队列快速排序(python按照多个条件排序的方法)
- node中如何用import(分析node事件循环和消息队列)
- laravel队列不超时(在laravel中实现事务回滚的方法)
- laravel队列大批量数据(laravel 中某一字段自增、自减的例子)
- phpredis消息队列(PHP+redis实现微博的推模型案例分析)
- axios 请求前校验参数(js实现axios限制请求队列)
- laravel自定义使用方法(Laravel使用Queue队列的技巧汇总)
- php消息队列redis(redis+php实现微博二发布与关注功能详解)
- python线程安全队列(Python 限制线程的最大数量的方法Semaphore)
- socket和tcp什么关系(TCP socket SYN队列和Accept队列区别原理解析)
- thinkphp5如何实现消息队列(thinkPHP5.1框架使用SemanticUI实现分页功能示例)
- 散文 八月再见,九月,我在风中等你(散文八月再见九月)
- 8月再见 9月你好(8月再见)
- 魔兽世界 设计师爆料,原始版本并无PVP,跨阵营属于返璞归真(魔兽世界设计师爆料)
- 吐槽完《弧光大作战》之后,我们和设计师聊了聊魔兽首款手游的立项初衷和未来(吐槽完弧光大作战之后)
- 魔兽争霸3自定义战役少年杰雷 2(魔兽争霸3自定义战役少年杰雷)
- 今日菜价 芥兰涨幅最高 1.33 ,花菜降幅最高 3.10(今日菜价芥兰涨幅最高)
热门推荐
- 利用数据库安装centos7(CentOS安装SQL Server vNext CTP1教程)
- mysql 死锁查询(MySQL slave 延迟一列 外键检查和自增加锁)
- sqlserver 开启数据库(SQLSERVER简单创建DBLINK操作远程服务器数据库的方法)
- python mongodb 基本操作(Python使用pymongo库操作MongoDB数据库的方法实例)
- mysql中date_format日期格式化
- python验证码处理教程(python简单验证码识别的实现方法)
- css3渐变动画(CSS3径向渐变radial-gradient实现波浪边框和内倒角的方法)
- html5的优点是什么
- microsoftsqlserver官网(Microsoft SQL Server数据库各版本下载地址集合)
- django请求流程(Django学习笔记之为Model添加Action)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9