thinkphp结合rabbitmq的使用案例

ThinkPHP是一款流行的PHP框架,RabbitMQ是一种消息中间件,在Web应用程序中使用它可以帮助处理异步任务和分发任务等。下面是一个ThinkPHP结合RabbitMQ的使用案例:

  1. 安装RabbitMQ

首先需要安装RabbitMQ。可以使用官方的RabbitMQ安装程序或者使用Docker容器来安装。安装后,需要启动RabbitMQ服务。

  1. 安装PHP的RabbitMQ扩展

在使用RabbitMQ之前,需要先安装PHP的RabbitMQ扩展。可以使用Composer在项目中安装。

  1. 编写任务发送和接收代码

在ThinkPHP项目中,编写任务发送和接收代码。例如,需要发送一个邮件可以将任务发送到RabbitMQ队列中,然后由异步任务来执行发送邮件的操作。代码示例:

复制代码
# 发送邮件任务
$data = array(
    'to' => 'user@example.com',
    'subject' => 'Hello',
    'content' => 'This is an email sent by RabbitMQ',
);

# 发送任务到RabbitMQ队列中
$exchange = 'email';
$queue = 'email_send';
$route_key = 'email.send';
$message = json_encode($data);

$connection = new \PhpAmqpLib\Connection\AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->exchange_declare($exchange, 'direct', false, true, false);
$channel->queue_declare($queue, false, true, false, false);
$channel->queue_bind($queue, $exchange, $route_key);
$msg = new \PhpAmqpLib\Message\AMQPMessage($message, array('delivery_mode' => 2));
$channel->basic_publish($msg, $exchange, $route_key);
$channel->close();
$connection->close();

接收任务也很简单,从RabbitMQ队列中获取任务执行。任务处理完成后,发送确认消息告诉RabbitMQ任务已经完成。代码示例:

复制代码
# 接收邮件任务
$exchange = 'email';
$queue = 'email_send';
$route_key = 'email.send';

$connection = new \PhpAmqpLib\Connection\AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->exchange_declare($exchange, 'direct', false, true, false);
$channel->queue_declare($queue, false, true, false, false);
$channel->queue_bind($queue, $exchange, $route_key);
$channel->basic_qos(null, 1, null);
$channel->basic_consume($queue, '', false, false, false, false, function ($msg) {
    $data = json_decode($msg->body, true);
    # 处理任务
    $result = send_email($data['to'], $data['subject'], $data['content']);
    if ($result === true) {
        # 发送确认消息
        $msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);
    } else {
        # 发送重新入队消息
        $msg->delivery_info['channel']->basic_nack($msg->delivery_info['delivery_tag'], false, true);
    }
});

while (count($channel->callbacks)) {
    $channel->wait();
}

$channel->close();
$connection->close();

以上代码示例仅供参考,实际使用中需要根据需求进行适当修改和调整。

相关推荐
大鸡腿同学1 小时前
从 CoT 思维链到 ReAct:智能 Agent 到底是怎么 “思考” 的?
后端
IT_陈寒3 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
SamDeepThinking4 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
Asize4 小时前
多模态生图:从 Vite 工程化到前端调用 Qwen Image
javascript·人工智能·后端
java小白小4 小时前
SpringBoot(09):缓存实战——穿透、雪崩、击穿的解决方案
后端
java小白小4 小时前
SpringBoot(08):Redis 集成——5 分钟给你的项目加上缓存
后端
LiuMingXin4 小时前
意图与代码之间:AI编程范式全景解读
前端·后端·面试
用户34232323763175 小时前
边缘计算与云边协同——当采集不再只是“上传“
后端
壹方秘境5 小时前
ApiCatcher支持抓包HTTP传输大文件的实现原理分享
前端·后端·客户端
神奇小汤圆5 小时前
2026最新·最全·最实用|Java岗面试真题(已收录GitHub)
后端