首页 php框架 Laravel laravel队列如何一直执行

laravel队列如何一直执行

May 21, 2023 am 09:45 AM

在使用 Laravel 的开发中,队列常常是必不可少的一部分。它能够极大的提高应用程序的并发处理能力,让大量的任务能够得到有效的管理和处理。但是在实际开发中,我们经常会遇到这样一个问题:队列不稳定,任务多时队列突然停止了,或者任务出现异常时队列也无法自动重启。这时我们就需要一些技巧,让队列能够稳定的运行下去。下面就介绍几种方法,帮助大家解决这些问题。

一、supervisor 守护进程

supervisor 是一款用 Python 写的进程控制系统,是 Linux 服务器上管理进程的一种常见的工具,可以帮助我们在后台不停的监控一个进程,如果这个进程因某种原因退出了,那么它能够随着宿主进程重新启动。这就能保证你的队列一直能够运行下去。

安装 supervisor

Centos 系统执行

yum install -y supervisor

Ubuntu 系统执行

apt-get install -y supervisor

打开配置文件

vim /etc/supervisord.conf

加入我们的 laravel-queue 配置节

[program:laravel-queue]
command=php /path/to/artisan queue:work redis --sleep=3 --tries=3
directory=/path/to/your/project
autostart=true
autorestart=true
user=www-data

说明:

  • program:定义进程的名称
  • command:定义运行命令
  • autostart:开机自启动
  • autorestart:自动重启
  • user:运行进程的用户

保存修改后加载配置

supervisorctl reload

启动队列

supervisorctl start laravel-queue

这样就可以实现对队列的守护进程了。如果队列停止了,这个进程就会自动重启,从而保证队列一直在运行。当然,配置文件中也可以通过配置运行多个 work 进程,提高队列处理能力。

二、使用 Hashicorp 的 Nomad 集成 Marathon

Hashicorp 的 Nomad 与 Marathon 操作类似,它们都是用于分布式任务编排的一款开源的工具。Nomad 通过抽象化任务的位置和决策,能够对一组不同类型的任务进行编排。Nomad 与 Marathon 相比具有轻量、用户体验度高、易于配置的优势。

使用 Nomad 需要 docker 环境,如果你没有安装 docker,可以先通过 apt-get 安装:

apt-get install -y docker.io

  1. 创建 Nomad Job

在项目根目录下创建 job.nomad 文件,通过配置创建一个 Nomad Job:

job "laravel_app" {
datacenters = ["dc1"]
type = "service"

group "app" {

task "laravel-queue" {
  driver = "docker"

  config {
    image = "your_docker_image"
    command = ["php", "artisan", "queue:work", "--tries", "1", "--timeout", "30"]
    args = [
      "--queue=critical,high,default,email,chat,sms",
      "--sleep=3"
    ]
    ports = ["http"]
  }

  resources {
    cpu    = 500
    memory = 128
    network {
      mbits = 10
      port "http" {}
    }
  }

  service {
    name = "laravel-queue"
    port = "http"
    check {
      type     = "http"
      path     = "/status"
      interval = "10s"
      timeout  = "2s"
    }
  }

  restart {
    attempts = 10
    interval = "5m"
    delay    = "25s"
    mode     = "failures"
  }
}
登录后复制

}
}

以上的配置文件在单机模式下使用的是 docker 运行,在生产环境下根据实际情况进行修改。

  1. 启动 Nomad Job

执行以下命令,启动 Nomad Job:

nomad run job.nomad

至此就完成了队列的启动。Nomad 会在一个节点上运行我们的 Job,同时可以对该 Job 进行监控;当任务出现问题,Nomad 可以快速的重启任务并更新状态。Nomad Job 可以在集群中的不同节点间自动迁移,这样可以减轻某个节点的负载,提高了总体应用程序的的鲁棒性。

三、使用 AWS SQS

AWS 的 SQS(Simple Queue Service)是一款用于消息队列的服务,它可以在分布式应用程序之间高效地传递和处理消息,并允许应用程序之间的消息处理能力实现水平伸缩。在 Laravel 框架中,SQS 可以非常方便地集成到我们的应用程序中,只需要安装支持 SQS 的 Laravel Queue 包即可。同时,在 AWS 的 SQS 中,每一个队列都有一个最小可生命周期(TTL),如果在该时间段内未被执行成功,则该任务会被 SQS 删掉。这样可以保证一个任务最终一定会被执行成功。

安装 SQS

在 Laravel 中集成 SQS 相对比较简单,只需要安装支持 SQS 的 Laravel Queue 包即可。可以直接通过 Composer 安装:

composer require "aws/aws-sdk-php ^3.0"

配置 SQS

在 .env 配置文件中添加以下内容:

QUEUE_DRIVER=sqs
AWS_ACCESS_KEY_ID=your_aws_access_key
AWS_SECRET_ACCESS_KEY=your_aws_secret_key
AWS_DEFAULT_REGION=us-west-2
SQS_PREFIX=your_queue_prefix

替换 your_aws_access_key、your_aws_secret_key 和 your_queue_prefix 为你自己的。

启动队列

php artisan queue:work sqs --queue=default --tries=3 --sleep=3 --timeout=60

以上命令会启动一个 SQS 队列,并使用默认的 default 队列,其中 --tries 参数表示队列任务出错尝试的次数,--sleep 表示队列处理完任务休息的时间,--timeout 表示队列任务超时时的自动重试时间。队列会不断循环获取任务并执行:

出现错误时,队列会自动重试,直至队列任务出错尝试的次数用完或者执行成功为止。

总结

在本文中,我们介绍了几种让 Laravel 队列一直执行的方法,通过守护进程、任务编排、第三方服务等方式,可以为队列提供更加稳定、高效的运行支持。每种方法都有各自的优点和适用范围,具体选择哪一种方法,需要根据自己的实际情况来做出决策。

以上是laravel队列如何一直执行的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何在Laravel中构建具有高级功能的宁静API? 如何在Laravel中构建具有高级功能的宁静API? Mar 11, 2025 pm 04:13 PM

本文指导建立强大的Laravel Restful Apis。 它涵盖项目设置,资源管理,数据库交互,序列化,身份验证,授权,测试和关键的安全性最佳实践。 解决可伸缩性chall

如何在Laravel中实施OAuth2身份验证和授权? 如何在Laravel中实施OAuth2身份验证和授权? Mar 12, 2025 pm 05:56 PM

本文详细介绍了Laravel实施OAuth 2.0身份验证和授权。 它涵盖了使用League/oauth2-server或提供商特定解决方案的软件包,强调数据库设置,客户端注册,授权服务器Configu

如何使用Laravel的组件来创建可重复使用的UI元素? 如何使用Laravel的组件来创建可重复使用的UI元素? Mar 17, 2025 pm 02:47 PM

本文讨论了使用组件在Laravel中创建和自定义可重复使用的UI元素,从而为组织提供最佳实践并建议增强包装。

在云原生环境中使用Laravel的最佳实践是什么? 在云原生环境中使用Laravel的最佳实践是什么? Mar 14, 2025 pm 01:44 PM

本文讨论了在云本地环境中部署Laravel的最佳实践,重点是可扩展性,可靠性和安全性。关键问题包括容器化,微服务,无状态设计和优化策略。

如何在Laravel中创建和使用自定义验证规则? 如何在Laravel中创建和使用自定义验证规则? Mar 17, 2025 pm 02:38 PM

本文讨论了Laravel中的创建和使用自定义验证规则,提供了定义和实施的步骤。它突出了诸如可重复性和特异性之类的好处,并提供了扩展Laravel验证系统的方法。

Laravel vs. Symfony:哪个适合您的Web应用程序? Laravel vs. Symfony:哪个适合您的Web应用程序? Mar 10, 2025 pm 01:34 PM

在选择PHP框架方面,Laravel和Symfony是最受欢迎和广泛使用的选项之一。每个框架都为桌子带来了自己的理念,特征和优势,使它们适合不同的项目和用例

如何在Laravel中创建和使用自定义刀片指令? 如何在Laravel中创建和使用自定义刀片指令? Mar 17, 2025 pm 02:50 PM

本文讨论了Laravel中的创建和使用自定义刀片指令以增强模板。它涵盖了定义指令,在模板中使用它们,并在大型项目中管理它们,强调了改进的代码可重复性和R等好处

在Laravel中处理文件上传和云存储的最佳方法是什么? 在Laravel中处理文件上传和云存储的最佳方法是什么? Mar 12, 2025 pm 05:54 PM

本文探讨了Laravel中最佳的文件上传和云存储策略。 它检查本地存储与云提供商(AWS S3,Google Cloud,Azure,Digitalocean),强调安全性(验证,消毒,HTTPS)和Performance Opti

See all articles