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实现异步发送电子邮件,极大地提升应用程序的响应速度和性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/22345.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024开放式耳机怎么买才好?这里可以教你六招!

有不少人都在说“开放式蓝牙耳机无音质”&#xff0c;大多数的购买者往往既贪恋蓝牙耳机的便携性&#xff0c;又想要有线耳机的Hifi快感&#xff0c;对于我们来说最重要的就是确定预算和需求&#xff0c;这样才能定位到最适合自己的开放式蓝牙耳机。这么多年零零总总听下来的蓝…

前端面试题日常练-day51 【面试题】

题目 希望这些选择题能够帮助您进行前端面试的准备&#xff0c;答案在文末 1. 在PHP中&#xff0c;以下哪个函数用于向浏览器发送一个HTTP头部&#xff1f; a) header() b) send() c) echo() d) print() 2. 哪个PHP函数用于将字符串转换为整数&#xff1f; a) stringToInt…

【python】成功解决“ModuleNotFoundError: No module named ‘IPython’”错误的全面指南

成功解决“ModuleNotFoundError: No module named IPython’”错误的全面指南 一、引言 在Python编程中&#xff0c;ModuleNotFoundError是一种常见的错误类型&#xff0c;它通常表明Python解释器无法找到你试图导入的模块。特别是当你遇到“ModuleNotFoundError: No module…

求助!什么软件可以人声分离?手机上可以进行人声分离操作吗?

在数字时代&#xff0c;音频处理变得越来越重要&#xff0c;而人声分离技术则是其中的一项关键技术。很多人可能都有过这样的疑问&#xff1a;什么软件可以实现人声分离&#xff1f;手机上能否进行人声分离操作&#xff1f;今天&#xff0c;我们就来为大家解答这些问题&#xf…

香港证监会十大牌照?

香港作为重要的国际金融中心&#xff0c;经济飞速发展&#xff0c;很多国内的朋友都在香港开展业务&#xff0c;以香港作为海外市场的跳板。金融交易牌照在国内还是不被许可的&#xff0c;在香港是有金融牌照管理制度的&#xff0c;开展不同的金融业务&#xff0c;需要向证监会…

【LLVM】LLVM out-of-tree方式

在阅读这篇文章时&#xff0c;发现了一种新的out-of-tree&#xff0c;遗憾的是作者文中的代码已经无法成功编译运行了&#xff0c;遂在网上搜索同类型文章&#xff0c;看到了本站有一篇文章&#xff0c;编译运行之后依旧发现失效&#xff0c;且目前LLVM使用的NewPassManager&am…

MySql学习(一)——MySQL概述之MySQL的启动

文章目录 一、MySQl概述1.1 启动MySQL1.2 客户端连接1.3 关系型数据库1.4 总结 一、MySQl概述 数据库&#xff1a;存储数据的仓库&#xff0c;数据是有组织的进行存储&#xff0c;简称为&#xff08;DB&#xff09;数据库管理系统&#xff1a;操纵和管理数据库的大型软件&…

微型计算机公司 Raspberry Pi 也开始涉足人工智能领域,计划出售AI芯片

Raspberry Pi 与 Hailo 合作&#xff0c;为其微型计算机提供可选的 AI 插件。 随着AI热潮的持续&#xff0c;就连微型计算机公司Raspberry Pi也计划出售AI芯片。它与 Raspberry Pi 的相机软件集成&#xff0c;可以在微型计算机上本地运行聊天机器人等基于人工智能的应用程序。…

官宣!活体人脸实名认证服务上新,更安全的身份核验服务,支持 H5页面和API 接入

忧郁的小某&#xff1a; 烦恼&#xff0c;太烦恼了&#xff01; 这年头&#xff0c;身份证真的太重要了&#xff01; 但我这种丢三落四的人&#xff0c; 用上10次身份证就有50%的可能性弄丢&#xff01; 总不能栓个随身携带的保险箱吧&#xff1f; 而且&#xff0c;弄丢不…

Python应用开发——30天学习Streamlit Python包进行APP的构建(6)

当我们想在界面上进行数据展示的时候,你就会发现我们需要进行数据交互式的应用开发,这里我们来看看如何实现? Data elements数据要素 在处理数据时,快速、交互式地从多个不同角度对数据进行可视化是非常有价值的。这就是 Streamlit 的构建和优化目的。 你可以通过图表显…

Maven实战: 创建自定义archetype

在手动创建SpringBoot应用中&#xff0c;我们讲过手动创建SpringBoot工程是比较麻烦的&#xff0c;尤其是公司内部不有自定义扩展和集成的情况下。利用Maven的archetype:generate能基于项目模板生成功能&#xff0c;自定义模板能让整个创建过程自动化&#xff0c;这样既能大大降…

【UML用户指南】-07-对基本结构建模-公共机制

目录 1、术语和概念 1.1、注解&#xff08;note&#xff09; 1.2、修饰 1.3、衍型 1.4、标记值 1.5、约束 1.6、标准元素 1.7、外廓&#xff08;profile&#xff09; 2、对新特性建模 3、对新语义建模 注解 &#xff08;note&#xff09;是附加在元素或元素集上用来表…

ICLR24大模型提示(2/11) | BatchPrompt:多样本批量提示事半功倍

【摘要】由于大型语言模型 (LLM) 的 token 限制不断增加&#xff0c;使得长上下文成为输入&#xff0c;使用单个数据样本进行提示可能不再是一种有效的方式。提高效率的一个直接策略是在 token 限制内对数据进行批处理&#xff08;例如&#xff0c;gpt-3.5-turbo 为 8k&#xf…

Python08 循环

循环1. while2. for循环控制1.back 退出当前循环2.continue 结束本次继续下次循环 i 0 while i < 10:print(f我正在学习python {i})i1 #循环增量 print(while 结束)while True:print(f我正在学习python {i})if i > 20:break #退出循环i1 #循环增量 print(while2 结束)# …

如何管理和维护组件库?

管理和维护组件库是一个关键的任务&#xff0c;因为它直接关系到产品的稳定性和功能的实现。以下是一些有效的方法来管理和维护组件库&#xff1a; 创建清晰的命名和文件结构&#xff1a;为每个组件分配一个有意义的名称&#xff0c;并根据功能和类型进行有层次的分类。确保文件…

【Python机器学习】无监督学习——不同类型的预处理

之前学习过&#xff0c;一些算法&#xff08;比如神经网络和SVM&#xff09;对数据缩放非常敏感。因此&#xff0c;通常的做法是对特征进行调节&#xff0c;使数据更适合于这些算法。通常来说&#xff0c;这是对数据的一种简单的按照特征的缩放和移动。举例&#xff1a; impor…

js图片跟随鼠标移动效果

js原生代码 要实现图片跟随鼠标移动的效果&#xff0c;可以使用JavaScript原生的mousemove事件以及CSS的transform属性。 HTML代码&#xff1a; <div id"container"><img id"image" src"path_to_image.jpg" alt"Image">…

【python】成功解决“ModuleNotFoundError: No module named ‘graphviz’”错误的全面指南

成功解决“ModuleNotFoundError: No module named ‘graphviz’”错误的全面指南 一、引言 在Python编程中&#xff0c;当尝试导入一个不存在的模块时&#xff0c;你会遇到ModuleNotFoundError错误。当你看到“ModuleNotFoundError: No module named ‘graphviz’”这样的错…

vue无需引入第三方, 将web页面内容直接下载为docx

vue无需引入第三方&#xff0c; 将web页面内容直接下载为docx 将web页面内容重绘 html &#xff0c;通过 a 标签直接下载 通过写行内样式&#xff0c;控制docx中的文字图效果 let echHtmlWithIf ;if (this.chartImg.length) {if (this.exceed10Min) {echHtmlWithIf <div…

Linux线程安全:线程互斥

一、线程互斥的概念 1.1临界资源与互斥的关系 临界资源&#xff1a;多线程执行流共享的资源就叫做临界资源。 临界区&#xff1a;每个线程内部&#xff0c;访问临界资源的代码&#xff0c;就叫做临界区。 互斥&#xff1a;任何时刻&#xff0c;互斥保证有且只有一个执行流进入…