Laravel 队列使用的实现
Laravel  /  管理员 发布于 5年前   361
1 环境 Laravel是一种类似ThinkPHP的php框架,封装的诸多功能可以很方便的使用。队列Queue便是其中之一。 Windows环境下,可使用PHPstorm作为Laravel的集成开发环境IDE。 2 队列 Laravel可配置多种队列驱动,包括 "sync", "database", "beanstalkd", "sqs", "redis", "null"(具体参见app/config/queue.php) 通过在 .env 中的 QUEUE_CONNECTION 选项,来决定选择何种驱动。 如 QUEUE_CONNECTION=database 即为选择数据库驱动队列。 3 原理 所谓队列,会有数据的生产者和消费者之分。生产者向队列中投递数据,消费者从队列中获取数据。 比如向用户发送邮件的场景:现在有10w封邮件需要发送,最简单的,我们需要有一个方法将邮件的收件人、内容等,拆分成10w条任务放在队列中,同时需要设置一个回调方法负责处理每条任务。当队列中有邮件发送任务时,队列会主动调用回调方法,并传递任务详情进去。回调方法处理完成后,单条邮件即发送完毕。其他邮件依样处理。 4 使用数据库驱动队列 4.1 生成任务表 在终端下输入 在数据库连接正常的情况下,会在数据库中出现jobs表: 4.2 创建任务类 在终端内执行上述命令,会自动生成 app/Jobs/SendMail.php 文件 在该文件的handle方法中,可以放置任务处理逻辑。 4.3 发送任务 在任意位置,均可像下面一样调用 dispatch 发送任务 4.4 驱动队列 完成上述步骤后,可以在数据库中发现一条记录(导出为insert SQL语句): 此时任务已经放置在数据库内,只有将队列运行起来后,队列才能主动调用回调方法。 在终端内运行上述命令即可。该命令还有诸多参数,如deamon、tries等,可根据需要指定。 4.5 守护进程 为了保证应用服务的稳定性,需要开启守护进程。 Linux下,一般使用 Supervisor ,Windows下使用 Forever 4.6 执行失败的处理 对于处理失败的任务,Laravel也提供的解决方案。通过运行如下命令,即可创建表以记录失败任务。 在数据库中即生成 failed_jobs : 导致任务失败的 Exception 会被传递到 SendMail 的 failed 方法,因而你需要在SendMail中自行实现该方法,并做进一步处理。 任务执行失败的原因有很多,如传参错误、尝试次数超过限制、超时、甚至在 handle 方法中抛出异常,均会作为失败任务处理。 4.7 任务执行前后的处理 Laravel提供了任务执行前后的处理入口,即在 App/Providers/AppServiceProvider 中的 boot() 中加入如下代码: 传递的 $event 中,带有任务详情,几个简单的例子: 5 使用 Redis 驱动队列 5.1 Laravel 安装 Predis 包 在 Laravel 中使用 Redis 之前,需要通过 Composer 安装 predis/predis 包: 上述拓展是帮助Laravel与Redis打交道的,我们现在还缺少Redis服务。 如果此时将 .env 中的 QUEUE_CONNECTION 改为 redis,访问时会报错: Predis \ Connection \ ConnectionException (10061) 5.2 配置 Redis 服务 在Redis官网 下载源码后自行编译即可。 官方并未提供Windows版,Redis的Windows版式由微软工作组维护的,你可以从其GitHub页 找到。不过貌似已经不再维护了,最新的版本是16年发布的3.2.100。 Linux下通过简单的运行 即可开启服务,再通过 来尝试使用Redis。使用也很简单,就是 set key value 和 get key。 即可开启Redis服务。 Redis服务的停止是通过如下命令: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
其中sync为同步,database为使用数据库,后面三种为第三方队列服务,最后一种为不使用队列。php artisan queue:tablephp artisan migrate
[id] bigint [queue] nvarchar(255) [payload] nvarchar(max) [attempts] tinyint [reserved_at] int [available_at] int [created_at] int
php artisan make:job SendEmail
class SendMail implements ShouldQueue
SendMail::dispatch($email);
php artisan queue:work
php artisan queue:failed-tablephp artisan migrate
[id] bigint [connection] nvarchar(max) [queue] nvarchar(max) [payload] nvarchar(max) [exception] nvarchar(max) [failed_at] datetime
public function boot(){ Queue::before( function (JobProcessing $event) { Log::info("处理任务前"); }); Queue::after( function (JobProcessed $event) { Log::info("处理任务后"); });}
$event->connectionName$event->job$event->job->payload()
composer require predis/predis
����Ŀ����������ܾ��������ӡ� [tcp://127.0.0.1:6379]./redis-server
./redis-cli
Windows下安装后,在命令行中 cd 到安装目录C:\Program Files\Redis>redis-server redis.windows.confC:\Program Files\Redis>netstat -an|find "6379" TCP 127.0.0.1:6379 0.0.0.0:0 LISTENING
C:\Program Files\Redis>redis-server --service-stop
您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号