Ubuntu+Laravel+MQ+Supervisor队列系统搭建流程

1、安装MQ环境

bash 复制代码
sudo apt install -y rabbitmq-server
sudo systemctl enable rabbitmq-server --now

2、进入laravel项目,安装MQ队列驱动

bash 复制代码
composer require vladimir-yuldashev/laravel-queue-rabbitmq

3、配置.env

bash 复制代码
QUEUE_CONNECTION=rabbitmq
RABBITMQ_HOST=127.0.0.1
RABBITMQ_PORT=5672
RABBITMQ_USER=guest
RABBITMQ_PASSWORD=guest

4、创建Job

bash 复制代码
php artisan make:job CallApiJob

5、安装 Supervisor

bash 复制代码
sudo apt update
sudo apt install supervisor

6、创建 Laravel 队列工作进程配置文件,在 /etc/supervisor/conf.d/ 目录下创建一个配置文件,例如 laravel-queue.conf,内容如下:

bash 复制代码
[program:laravel-queue]
process_name=%(program_name)s_%(process_num)02d
command=php /path/to/artisan queue:work --queue=ApiCoupons --tries=3 --daemon
autostart=true
autorestart=true
numprocs=2
redirect_stderr=true
stdout_logfile=/dev/null

7、修改supervisor.conf配置加入以下配置:

bash 复制代码
[include]
files = /etc/supervisor/conf.d/*.conf

8、重载 Supervisor 配置并启动

bash 复制代码
sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start laravel-queue:*

9. 使用 Git Hook 自动重启

如果你在项目中使用 Git 进行版本控制,你可以利用 Git hooks(例如 post-merge 或 post-checkout)来触发 php artisan queue:restart 命令。

配置方法:

  • 创建 Git hook 脚本

在你的项目根目录下,进入 .git/hooks 目录,创建一个 post-merge 或 post-checkout 脚本。

  • 编辑 post-merge文件
bash 复制代码
nano .git/hooks/post-merge

在文件中添加以下内容:

bash 复制代码
#!/bin/bash
php /path/to/artisan queue:restart
  • post-merge文件执行权限
bash 复制代码
chmod +x .git/hooks/post-merge

这样,当你执行 git pull 或 git checkout 后,Git 会自动执行 php artisan queue:restart,从而重启队列进程并使其使用最新代码。

相关推荐
佩奇的技术笔记11 分钟前
CentOS系统中升级Python 3.12.2版本
linux·运维·服务器
Fireworkitte11 分钟前
CentOS 和 RHEL
linux·centos
chilavert31834 分钟前
从RPA项目说说RPC和MQ的使用。
开发语言·qt·rpc·rabbitmq
丢掉幻想准备斗争1 小时前
Linux-进程概念(一)
linux
孤的心了不冷1 小时前
【Docker】CentOS 8.2 安装Docker教程
linux·运维·docker·容器·eureka·centos
程序员JerrySUN3 小时前
Linux 内核核心知识热点题分析:10 个连环打通的难点
linux·运维·服务器
R_.L4 小时前
Linux : 线程【同步与互斥】
linux
再睡一夏就好4 小时前
从硬件角度理解“Linux下一切皆文件“,详解用户级缓冲区
linux·服务器·c语言·开发语言·学习笔记
honey ball9 小时前
R & S的EMI接收机面板
linux·运维·网络
@小了白了兔10 小时前
RabbitMQ工作流程及使用方法
分布式·rabbitmq