【消息队列】RabbitMQ+PHP实现

本文链接:http://www.cnblogs.com/aiweixiao/p/7374249.html

文档提纲:

扫描关注微信公众号

1.【下载和安装】

  1)gitHub下载地址: https://github.com/php-amqplib/php-amqplib

  2)【环境准备】:

安装php的RabbitMQ PHP扩展安装,依赖的Erlang环境

   参考文档: http://www.cnblogs.com/chunguang/p/5634342.html

  3)【类的依赖加载】:建议使用 composer实现,

composer入门

4)【教程】:

    官方教程链接地址:http://www.rabbitmq.com/tutorials/tutorial-one-php.html

  5)测试脚本:

--使用官方的demo:

开一个订阅者窗口
$ cd php-amqplib/demo
$ php amqp_consumer.php

开一个发布者窗口
$ cd php-amqplib/demo
$ php amqp_publisher.php some text to publish

    --使用第三方脚本 http://blog.csdn.net/u014071426/article/details/53649226

 1 //引用所需文件
 2 require_once __DIR__ . ‘/vendor/autoload.php‘;
 3 use PhpAmqpLib\Connection\AMQPStreamConnection;
 4 use PhpAmqpLib\Message\AMQPMessage;
 5 //建立一个连接通道,声明一个可以发送消息的队列hello
 6 $connection = new AMQPStreamConnection(‘localhost‘, 5672, ‘guest‘, ‘guest‘);
 7 $channel = $connection->channel();
 8 $channel->queue_declare(‘hello‘, false, false, false, false);
 9
10 //定义一个消息,消息内容为Hello World!
11 $msg = new AMQPMessage(‘Hello World!‘);
12 $channel->basic_publish($msg, ‘‘, ‘hello‘);
13
14 //发送完成后打印消息告诉发布消息的人:发送成功
15 echo " [x] Sent ‘Hello World!‘\n";
16 //关闭连接
17 $channel->close();
18 $connection->close();

 1     require_once __DIR__ . ‘/vendor/autoload.php‘;
 2     use PhpAmqpLib\Connection\AMQPStreamConnection;
 3     $connection = new AMQPStreamConnection(‘localhost‘, 5672, ‘guest‘, ‘guest‘);
 4     $channel = $connection->channel();
 5
 6     $channel->queue_declare(‘hello‘, false, false, false, false);
 7
 8     echo ‘ [*] Waiting for messages. To exit press CTRL+C‘, "\n";
 9     $callback = function($msg) {
10       echo " [x] Received ", $msg->body, "\n";
11     };
12
13     //在接收消息的时候调用$callback函数
14     $channel->basic_consume(‘hello‘, ‘‘, false, true, false, false, $callback);
15
16     while(count($channel->callbacks)) {
17         $channel->wait();
18     }  
时间: 2025-01-02 03:23:43

【消息队列】RabbitMQ+PHP实现的相关文章

消息队列RabbitMQ

消息队列RabbitMQ 一.RabbitMQ是什么? AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计.消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然.AMQP的主要特征是面向消息.队列.路由(包括点对点和发布/订阅).可靠性.安全.RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python.Ruby..NET.J

消息队列--RabbitMQ(一)

1.消息队列概述 可以理解为保存消息的一个媒介/或者是个容器,与之相关有两个概念(即生产者(Publish)与消费者(Consumer)).所谓生产者,就是生产创造消息的一方,那么,消费者便是从队列中取出消息,完成相应的某种目的.总而言之,消息队列是搭建生产者与消费者沟通的一座桥梁. 消息队列的产品也很多,作用也各有千秋.常见的消息队列有RabbitMQ.RocketMq.KafKa,本系列文章将以(RabbitMQ+C#客户端+Windonw)为例去探索消息队列的基本用途及相关使用.闲话不说,

ASP.NET Core消息队列RabbitMQ基础入门实战演练

一.课程介绍 人生苦短,我用.NET Core!消息队列RabbitMQ大家相比都不陌生,本次分享课程阿笨将给大家分享一下在一般项目中99%都会用到的消息队列MQ的一个实战业务运用场景.本次分享课程不是零基础教学,课程内容的侧重点是讲解的RabbitMQ的最实用.最简单的实战运用场景:Publish/Subscrib(发布/订阅)模式,发送端发送消息,单个接收端接收处理消息. 学完本次"是猴子都看的懂的消息队列RabbitMQ实战课程"后,阿笨带直接让你也能如此优雅简单的上手使用Rab

消息队列rabbitmq的五种工作模式(go语言版本)

前言:如果你对rabbitmq基本概念都不懂,可以移步此篇博文查阅消息队列RabbitMQ 一.单发单收 二.工作队列Work Queue 三.发布/订阅 Publish/Subscribe 四.路由Routing 五.Topic类型的exchange 六.rabbitmq部分封装代码及装备工作 一.单发单收 在下图中,“ P”是我们的生产者,“ C”是我们的消费者.中间的框是一个队列-RabbitMQ代表使用者保留的消息缓冲区. 单发单收模式下:一发一收 发送端只需要创建队列,然后向队列发送消

(转)(二)RabbitMQ消息队列-RabbitMQ消息队列架构与基本概念

http://blog.csdn.net/super_rd/article/details/70238869 没错我还是没有讲怎么安装和写一个HelloWord,不过快了,这一章我们先了解下RabbitMQ的基本概念. RabbitMQ架构 说是架构其实更像是应用场景下的架构(自己画的有点丑,勿嫌弃) 从图中可以看出RabbitMQ主要由Exchange和Queue两部分组成,然后通过RoutingKey关联起来,消息投递到Exchange然后通过Queue接收. RabbitMQ消息队列基本概

消息队列 RabbitMQ

前言 市面上的消息队列产品有很多,比如老牌的 ActiveMQ.RabbitMQ ,目前我看最火的 Kafka ,还有 ZeroMQ ,阿里巴巴捐赠给 Apache 的 RocketMQ ,连 redis 这样的 NoSQL 数据库也支持 MQ 功能.总之这块知名的产品就有十几种. 什么是rabbitMQ RabbitMQ 是一个由 Erlang 语言开发的 AMQP 的开源实现.一款基于AMQP协议的消息中间件,它能够在应用之间提供可靠的消息传输.在易用性,扩展性,高可用性上表现优秀.而且使用

自动化运维Python系列之消息队列RabbitMQ

RabbitMQ RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然在同步消息通讯的世界里有很多公开标准(如 COBAR的 IIOP ,或者是 SOAP 等),但是在异步消息处理中却不是这样,只有大企业有一些商业实现(如微软的 MSMQ ,IBM 的 Websphere MQ 等),因此,在 2006 年的 6 月,Cisco .Redhat.iMatix 等联合制定了 AMQP 的

消息队列 RabbitMQ 入门介绍

来源:http://ityen.com/archives/578 一.什么是RabbitMQ? RabbitMQ是实现AMQP(高级消息队列协议)的消息中间件的一种,最初起源于金融系统,用于在分布式系统中存储转发消息,在易用性.扩展性.高可用性等方面表现不俗.消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然:   例如一个日志系统,很容易使用RabbitMQ简化工作量,一个Consumer可以进行消息的正常处理,另一个Consumer负责对消息进行日志记录,只要在

php 消息队列 rabbitmq 的安装使用

今天尝试安装了 rabbitmq ,用作php 的消息队列,下面是具体的步骤 首先呢,需要在github 下载这个包,我这里用的是 v0.5.2 版本的 rabbitmq v0.5.2 接下来,通过 使用 .sh脚本,进行安装 1 #切换目录到 rabbittmq-c ,更改文件属性 2 chmod -a+x travis.sh 3 4 #初始化 5 ./travis.sh autotools 6 7 #安装 8 ./travis.sh cmake 再然后,使用 pecl 安装php 的 amq

python中消息队列RabbitMQ的使用

1,简介 RabbitMQ(Rabbit Message Queue)是流行的开源消息队列系统,用erlang语言开发. 1.1关键词说明: Broker:消息队列服务器实体.Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列.Queue:消息队列载体,每个消息都会被投入到一个或多个队列.Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来.Routing Key:路由关键字,exchange根据这个关键字进行消息投递.vhost:虚拟主机,一个b