rabbitmq php使用demo,PHP 使用 Rabbitmq Demo

一、发布消息类(client.php),发布者

$conn = [

‘host‘ => ‘127.0.0.1‘,

‘port‘ => ‘5672‘,

‘login‘ => ‘guest‘,

‘password‘ => ‘guest‘,

‘vhost‘=>‘/‘

];

//创建连接和channel

$conn = new AMQPConnection($conn);

if(!$conn->connect()) {

die("Cannot connect to the broker!\n");

}

$channel = new AMQPChannel($conn);

// 用来绑定交换机和队列

$routingKey = ‘key_1‘;

$ex = new AMQPExchange($channel);

// 交换机名称

$exchangeName = ‘ex1‘;

$ex->setName($exchangeName);

// 设置交换机类型

$ex->setType(AMQP_EX_TYPE_DIRECT);

// 设置交换机是否持久化消息

$ex->setFlags(AMQP_DURABLE);

$ex->declare();

for($i=0; $i<5; ++$i){

echo "Send Message:".$ex->publish(date(‘H:i:s‘)."用户".$i."注册" , $routingKey )."\n";

}

二、接受消息类(server.php),订阅者

$conn = [

‘host‘ => ‘127.0.0.1‘,

‘port‘ => ‘5672‘,

‘login‘ => ‘guest‘,

‘password‘ => ‘guest‘,

‘vhost‘=>‘/‘

];

//创建连接和channel

$conn = new AMQPConnection($conn);

if(!$conn->connect()) {

die("Cannot connect to the broker!\n");

}

$channel = new AMQPChannel($conn);

$exchangeName = ‘ex1‘;

//创建交换机

$ex = new AMQPExchange($channel);

$ex->setName($exchangeName);

$ex->setType(AMQP_EX_TYPE_DIRECT); //direct类型

$ex->setFlags(AMQP_DURABLE); //持久化

$ex->declare();

// 创建队列

$queueName = ‘queue1‘;

$q = new AMQPQueue($channel);

$q->setName($queueName);

$q->setFlags(AMQP_DURABLE);

$q->declareQueue();

// 用于绑定队列和交换机,跟 send.php 中的一致。

$routingKey = ‘key_1‘;

$q->bind($exchangeName, $routingKey);

//接收消息

$q->consume(function ($envelope, $queue) {

$msg = $envelope->getBody();

echo $msg."\n"; //处理消息

}, AMQP_AUTOACK);

$conn->disconnect();

三、需要将订阅者常驻于后台进程。

这里先使用下命令

php server.php

然后打开另一个终端,使用

php client.php

原文:https://www.cnblogs.com/licnlt/p/9498021.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RabbitMQ是一个流行的消息中间件,支持多种消息队列协议,并提供了可靠的消息传输机制。手动确认是RabbitMQ中保证消息可靠传递的一种方式。 手动确认是指,消费者在处理完消息后,需要手动向RabbitMQ确认消息已经成功处理。这样做的好处是,可以确保消息不会在传输过程中丢失或重复发送。下面介绍一下如何使用RabbitMQ手动确认机制。 首先,我们需要创建一个消息队列和一个消费者。在Python中,可以使用pika库实现RabbitMQ的操作。以下是创建消息队列的代码示例: ```python import pika connection = pika.BlockingConnection(pika.ConnectionParameters(host='localhost')) channel = connection.channel() channel.queue_declare(queue='hello') ``` 接下来,我们需要编写一个消费者来处理队列中的消息。下面是一个简单的处理函数: ```python def callback(ch, method, properties, body): print("Received %r" % body) ch.basic_ack(delivery_tag=method.delivery_tag) ``` 在本例中,在处理完消息后必须调用`ch.basic_ack(delivery_tag=method.delivery_tag)`来确认消息已经成功处理。 最后,我们需要将消息队列和消费者绑定在一起: ```python channel.basic_consume(queue='hello', on_message_callback=callback) channel.start_consuming() ``` 这样,消费者就会开始监听消息队列,并在收到消息时调用`callback`函数进行消息处理。处理完成后,调用`basic_ack`函数确认消息已经成功处理。 总之,手动确认是RabbitMQ保证消息可靠传递的重要手段。在使用时需要注意,确保在处理完消息后一定要手动确认。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值