PHP中使用RabbitMQ实现异步发送电子邮件可以显著提升应用的表现,尤其是在需要大量发送邮件的场景下

本文主要是介绍PHP中使用RabbitMQ实现异步发送电子邮件可以显著提升应用的表现,尤其是在需要大量发送邮件的场景下,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前提条件

安装RabbitMQ服务。

安装PHP的RabbitMQ客户端库(php-amqplib)。

安装邮件发送库(如PHPMailer)。

安装php-amqplib和PHPMailer

首先,通过Composer安装这些库:

composer require php-amqplib/php-amqplib
composer require phpmailer/phpmailer

发送邮件到RabbitMQ队列

以下代码展示了如何创建一个PHP生产者,用于将发送邮件的任务推送到RabbitMQ队列中。

生产者代码 (producer.php)

<?php
require_once 'vendor/autoload.php';use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;// RabbitMQ连接信息
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->queue_declare('email_queue', false, true, false, false);// 邮件数据
$emailData = ['to' => 'recipient@example.com','subject' => 'Test Email','body' => 'This is a test email.'
];
$emailJson = json_encode($emailData);$msg = new AMQPMessage($emailJson, ['delivery_mode' => 2]);
$channel->basic_publish($msg, '', 'email_queue');echo " [x] Sent email task to queue\n";$channel->close();
$connection->close();
?>

消费队列发送邮件

接下来,编写消费者代码,从RabbitMQ队列中获取任务并发送邮件。

消费者代码 (consumer.php)

<?php
require_once 'vendor/autoload.php';use PhpAmqpLib\Connection\AMQPStreamConnection;
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;// RabbitMQ连接信息
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->queue_declare('email_queue', false, true, false, false);echo " [*] Waiting for email tasks. To exit press CTRL+C\n";$callback = function ($msg) {$emailData = json_decode($msg->body, true);sendEmail($emailData);echo " [x] Sent email to " . $emailData['to'] . "\n";
};$channel->basic_consume('email_queue', '', false, true, false, false, $callback);while($channel->is_consuming()) {$channel->wait();
}$channel->close();
$connection->close();function sendEmail($emailData) {$mail = new PHPMailer(true);try {// 服务器设置$mail->isSMTP();$mail->Host       = 'smtp.example.com';  // 请设置 SMTP 服务器地址$mail->SMTPAuth   = true;$mail->Username   = 'your_email@example.com';  // SMTP 用户名$mail->Password   = 'your_email_password';  // SMTP 密码$mail->SMTPSecure = 'tls';  // 启用TLS加密$mail->Port       = 587;  // TCP端口号// 收件人$mail->setFrom('your_email@example.com', 'Mailer');$mail->addAddress($emailData['to']);// 内容$mail->isHTML(true);$mail->Subject = $emailData['subject'];$mail->Body    = $emailData['body'];$mail->send();echo "Message has been sent\n";} catch (Exception $e) {echo "Message could not be sent. Mailer Error: {$mail->ErrorInfo}\n";}
}
?>

使用Supervisor管理消费者进程

为了确保消费者进程始终在运行,可以使用Supervisor来管理。

安装Supervisor
在Ubuntu上可以使用以下命令安装:

sudo apt-get install supervisor

配置Supervisor
/etc/supervisor/conf.d目录下创建一个新的配置文件,如email_consumer.conf

[program:email_consumer]
command=php /path/to/your/consumer.php
autostart=true
autorestart=true
stderr_logfile=/var/log/email_consumer.err.log
stdout_logfile=/var/log/email_consumer.out.log

重新加载Supervisor配置:

sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start email_consumer

测试

1、运行php producer.php将邮件任务发送到队列。

2、确保消费者(php consumer.php)正在运行并处理队列中的任务。

通过这种方式,您可以在PHP中使用RabbitMQ实现异步发送电子邮件,极大地提升应用程序的响应速度和性能。

这篇关于PHP中使用RabbitMQ实现异步发送电子邮件可以显著提升应用的表现,尤其是在需要大量发送邮件的场景下的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1020411

相关文章

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个