今天用一个简单的案例来实现 RabbitMQ + PHP 这个消息队列的运行机制。
主要分为两个部分:
第一:发送者(publisher)
第二:消费者(consumer)
(一)生产者 (创建一个rabbit_publisher.php的文件)
创建连接-->创建channel-->创建交换机对象-->发送消息
$conn_args = array( 'host' => '127.0.0.1', 'port' => '5672', 'login' => 'guest', 'password' => 'guest', 'vhost'=>'/');//创建连接和channel$conn = new AMQPConnection($conn_args);if (!$conn->connect()) { die("Cannot connect to the broker!\n");}$channel = new AMQPChannel($conn);//创建交换机$e_name = 'e_linvo'; //交换机名$ex = new AMQPExchange($channel);$ex->setName($e_name);$ex->setType(AMQP_EX_TYPE_DIRECT); //direct类型$ex->setFlags(AMQP_DURABLE); //持久化echo "Exchange Status:".$ex->declare()."\n";echo "Send Message:".$ex->publish("TEST MESSAGE,key_1 by 松涛" . date('H:i:s', time()), 'key_1')."\n";echo "Send Message:".$ex->publish("TEST MESSAGE,key_2 by 松涛" . date('H:i:s', time()), 'key_2')."\n";
(二)消费者(创建一个rabbit_consumer.php的文件)
创建连接-->创建channel-->创建交换机-->创建队列-->绑定交换机/队列/路由键-->接收消息
$conn_args = array( 'host' => '127.0.0.1', 'port' => '5672', 'login' => 'guest', 'password' => 'guest', 'vhost'=>'/');$e_name = 'e_linvo'; //交换机名$q_name = 'q_linvo'; //队列名$k_route = 'key_2'; //路由key//创建连接和channel$conn = new AMQPConnection($conn_args);if (!$conn->connect()) { die("Cannot connect to the broker!\n");}$channel = new AMQPChannel($conn);//创建交换机$ex = new AMQPExchange($channel);$ex->setName($e_name);$ex->setType(AMQP_EX_TYPE_DIRECT); //direct类型$ex->setFlags(AMQP_DURABLE); //持久化echo "Exchange Status:".$ex->declare()."\n";//创建队列$q = new AMQPQueue($channel);$q->setName($q_name);$q->setFlags(AMQP_DURABLE); //持久化//绑定交换机与队列,并指定路由键echo 'Queue Bind: '.$q->bind($e_name, 'key_2')."\n"; //阻塞模式接收消息echo "Message:\n";$q->consume('processMessage', AMQP_AUTOACK); //自动ACK应答$conn->disconnect();/** * 消费回调函数 * 处理消息 */function processMessage($envelope, $queue) { var_dump($envelope->getRoutingKey); $msg = $envelope->getBody(); echo $msg."\n"; //处理消息}
执行两个文件,再打开RabbitMQ的管理中心 http://127.0.0.1:15672/
说明你的程序运行是正常的。
如果有什么地方说错了,望,批评指正!谢谢。
原标题:RabbitMQ + PHP (三)案例演示
关键词:PHP