触发

任务的触发,主要的实现是在IlluminateFoundationBusDispatchesJobs这个trait中实现的,其只包含两个方法

protected function dispatch($job){
return app(Dispatcher::class)->dispatch($job);
} protected function dispatchNow($job){
return app(Dispatcher::class)->dispatchNow($job);
}

这两个方法的区别就在于时间上,一个是推送到队列,另外一个是推送并立即执行,依据前面的traitQueueable可知,我们可以在对任务进行设置,例如

protected function hpJob(){
$job = (new HappybirdJob(5))->onConnection("other")
->onQueue("happybird")
->delay(5);
}

以上例子表示,我们使用other的连接在happybird队列中设置一个延迟时间为5sHappybirdJob任务

由于dispatch, dispatchNow都是使用的是容器中绑定的Dsipatch类,接下来看一下这个类
这个类位于IlluminateBusDispatcher

Dispatch

该类主要是用于队列任务的分发以及设置,其中可以看到

    public function dispatch($command)
{
if ($this->queueResolver && $this->commandShouldBeQueued($command)) {
return $this->dispatchToQueue($command);
} else {
return $this->dispatchNow($command);
}
}

当使用dispatch类触发任务时,将需要判断是否实现了ShouldQueue,这个就是之前在讨论异步队列和同步队列时两个不同的列所实现的差异

而对于立即执行的操作来说,则是通过管道来执行

    public function dispatchNow($command)
{
return $this->pipeline->send($command)
->through($this->pipes)
->then(function ($command) {
return $this->container->call([$command, 'handle']);
});
}

对于管道的说明和解释,可以参考
Laravel Pipeline 组件的实现,
Understanding Laravel Pipelines这两篇文章

执行

对于推送到队列里面的任务,可以通过artisan命令及其参数来进行控制,通过如下命令查看详情

$ php artisan list | grep queue

将可以得到如下的结果:

  queue:failed        List all of the failed queue jobs
queue:failed-table Create a migration for the failed queue jobs database table
queue:flush Flush all of the failed queue jobs
queue:forget Delete a failed queue job
queue:listen Listen to a given queue
queue:restart Restart queue worker daemons after their current job
queue:retry Retry a failed queue job
queue:table 大专栏  Laravel 队列使用 Create a migration for the queue jobs database table
queue:work Process the next job on a queue

这里需要特别注意的是,queue:work, queue:listen这两个命令,其余的都没有额外的参数

queue:listern
--queue[=QUEUE]      The queue to listen on
--delay[=DELAY] Amount of time to delay failed jobs [default: 0]
--memory[=MEMORY] The memory limit in megabytes [default: 128]
--timeout[=TIMEOUT] Seconds a job may run before timing out [default: 60]
--sleep[=SLEEP] Seconds to wait before checking queue for jobs [default: 3]
--tries[=TRIES] Number of times to attempt a job before logging it failed [default: 0]
queue:work
--queue[=QUEUE]    The queue to listen on
--daemon Run the worker in daemon mode
--delay[=DELAY] Amount of time to delay failed jobs [default: 0]
--force Force the worker to run even in maintenance mode
--memory[=MEMORY] The memory limit in megabytes [default: 128]
--sleep[=SLEEP] Number of seconds to sleep when no job is available [default: 3]
--tries[=TRIES] Number of times to attempt a job before logging it failed [default: 0]

相同:

  • queue: 当包含多个队列时,指定其执行的优先级,优先级顺序为:越往前优先级越高
  • delay: 失败队列的延迟执行时间
  • memory: 任务执行的最大使用内存,默认为128M
  • tries: 任务失败后,尝试运行的次数,默认为不启动

差异:
对于listen来说,其包含一个--timeout参数,用来置顶执行的时间,超过该时间,将会造成任务失败,程序异常,队列停止

--sleep选项对于listen来说,表示暂时未有任务执行时,重新执行任务需要的时间,对于queue:work来说,则表示当没有任务运行时,重新检测任务的时间间隔

queue:work还有一项特别的参数就是用来指定work运行的模式,如果启用,则会强制队列服务器持续处理任务,无需重启框架

守护

官方推荐使用Supervisor来守护队列的进程,其推荐的配置如下:

[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 --daemon
autostart=true
autorestart=true
user=forge
numprocs=8
redirect_stderr=true
stdout_logfile=/home/forge/app.com/worker.log
  • command:用来设置运行的命令,这个需要替换成自己的环境配置
  • numprocs: 监控的进程数量,需要注意的是,进程的数量不能设置过大

Please enable JavaScript to view the comments powered by Disqus.

Laravel 队列使用的更多相关文章

  1. Laravel 队列不执行的原因,job缓存

    laravel关于异步消息队列queue不生效(job缓存)解决办法 php artisan queue:restart 每次修改代码都需要执行上面的命令,执行后成功解决! 然后再次执行 php ar ...

  2. laravel 队列服务使用总结

    laravel 队列服务使用总结 使用步骤 配置队列驱动 //env文件,有的版本是QUEUE_DRIVER QUEUE_CONNECTION=database 迁移队列需要的数据表,在数据库中生成j ...

  3. laravel队列

    三种情况: queue:work 默认只执行一次队列请求, 当请求执行完成后就终止; queue:listen 监听队列请求, 只要运行着, 就能一直接受请求, 除非手动终止; queue:work ...

  4. laravel队列-让守护进程处理耗时任务

    待解决的问题 最近在做一个服务器集群管理的web项目,需要处理一些极其耗时的操作,比如磁盘格式化分区.对于这个需求,最开始的想法是,为了让节点上的rpc(远程过程调用) service端尽可能简单(简 ...

  5. laravel 队列发送邮件

    批量处理任务的场景在我们开发中是经常使用的,比如邮件群发,消息通知,短信,秒杀等等,我们需要将这个耗时的操作放在队列中来处理,从而大幅度缩短Web请求和相应的时间.下面讲解下Laravel中队列的使用 ...

  6. laravel队列使用

    1.修改.env中queue_driver = databases 2.php artisan queue:table 在database 目录下migrations里面有对应的表 3.执行迁移文件 ...

  7. laravel队列,事件简单使用方法

    A.队列的使用 1.队列配置文件存储在 config/queue.php 根据自己的情况进行配置 2..env文件 QUEUE_DRIVER=database(根据个人情况配置,redis等) 3.创 ...

  8. PHP Laravel 队列技巧:Fail、Retry 或者 Delay

    当创建队列jobs.监听器或订阅服务器以推送到队列中时,您可能会开始认为,一旦分派,队列工作器决定如何处理您的逻辑就完全由您自己决定了. 嗯……并不是说你不能从作业内部与队列工作器交互,但是通常情况下 ...

  9. Laravel 队列的简单使用例子

    场景: 在一个a系统中注册一个用户时,发送请求到b系统中也注册一个相同信息的账号,考虑到网络有可能错误的原因,所以使用队列去处理 1.修改根目录 .env 文件的QUEUE_CONNECTION字段配 ...

随机推荐

  1. Postgresql的导表

    背景 前面已经介绍了常用的备份与恢复了,接下来介绍一下导表. 正文 很多情况,会有把数据导出的需求,轻重缓急总会有特别紧急的情况,但是又不是专业干db的人,还是记录下来,以防不时之需. 针对于导表,个 ...

  2. eureka学习之二:自我保护机制

    提供者和消费者:消费者通过注册服务名称,找rpc远程地址,调用提供者的接口 Eureka的自我保护机制:

  3. python uiautomator2 新版本2.4.6之watcher的玩法

    最近将uiautomator2升级到最新版本了,运行之前的脚本发现涉及watcher部分的全部报错,大家来看看新版本的watcher如何玩 用法举例 注册监控 # 常用写法,注册匿名监控 d.watc ...

  4. 17.3.13--pycharm2和3的常识问题

    1------pycharm 3~支持print(),不支持那个 print+一个空格的形式 pycharm2~~支持print+一个空格,,也支持那个print()形式 虽然print语法是Pyth ...

  5. istio介绍

    核心架构 解决的问题 故障排查 1.  这个请求在哪里失败了?A有调用B吗? 2.  为什么用户的请求/页面hung住了? 3.  为什么系统这么慢?那个组件最慢? 应用容错性 1.  客户端没有配置 ...

  6. python摄像头

    import cv2 cap = cv2.VideoCapture(0) i = 0 while 1: ret, frame = cap.read() k = cv2.waitKey(1) if k ...

  7. 史上最强maven配置详情

    史上最强maven配置详情 优点 对第三方依赖库进行了统一的版本管理 统一了构建过程 统一了项目的目录结构 构建 清理 : mvn clear 编译 : mvn compile 测试 : mvn te ...

  8. Exynos4412开发板-网络-同一网段

    1.1 同一网段在不少实验中,都会需要用到局域网的一些基础知识,在技术支持的过程中,发现不少用户对于这个概念非常模糊,导致 IP 地址或者网络环境稍微有点变化,就无法实现实验.如果没有接触过这个概念, ...

  9. UML Learning

    在建筑业中,建模是一项经过检验并被广泛接受的工程技术,建立房屋和大厦的建筑模型,能帮助用户得到实际建筑物的印象.在软件建模中也具有同样的作用,建模提供了系统的蓝图. 建模是为了能够更好地理解正在开发的 ...

  10. python语法基础-基础-控制语句

    ###############    if条件控制语句    ############### # 以下实例 x 为 0-99 取一个数,y 为 0-199 取一个数,如果 x>y 则输出 x,如 ...