PHP中RabbitMQ之amqp扩展实现(四)
环境:CoentOS,PHP 7
1、RabbitMQ的安装
需要下载的两个包
erlang-21.0.7-1.el7.centos.x86_64.rpm
rabbitmq-server-3.7.7-1.el7.noarch.rpm
这两个包我已经放在了百度云盘的分享上
链接:https://pan.baidu.com/s/1rMv_yFpLnH-D1S5wrOZrbA#list/path=%2FRabbitMQ
提取码:ipyu
然后参照 weixin_41368339的博客linux rabbitmq3.7.7安装与使用一文中的步骤安装步,基本上没有什么问题
2、amqp扩展的安装
这个请参照一只猪儿虫的linux 编译安装amqp一文中的步骤安装,也没有什么问题
当安装成功之后,即可开始用amqp实现RabbitMQ了
3、Demo示例
在安装完成后我们就可以开始我们的RabbitMQ之旅了,本Demo示例只创建了一个直连交换机,共有四个文件Consum.php (消费者),Publish.php (生产者) ,RabbitMqParernt.php (自己封装的RabbitMQ的方法) ,以及test.php (测试数据)
RabbitMqParernt.php如下所示
- <?php
- abstract class RabbitMqParernt
- {
- //rabbitMQ配置信息(默认配置)
- public $config = array(
- 'host'=>'127.0.0.1', //host
- 'port'=>5672, //端口
- 'username'=>'guest', //账号
- 'password'=>'guest', //密码
- 'vhost'=>'/' //虚拟主机
- );
- public $exchangeName = ''; //交换机
- public $queueName = ''; //队列名
- public $routeKey = ''; //路由键
- public $exchangeType = ''; //交换机类型
- public $channel; //信道
- public $connection; //连接
- public $exchange; //交换机
- public $queue; //队列
- //初始化RabbitMQ($config数组是用来修改rabbitMQ的配置信息的)
- public function __construct($exchangeName, $queueName, $routeKey, $exchangeType = '',$config = array())
- {
- $this->exchangeName = $exchangeName;
- $this->queueName = $queueName;
- $this->routeKey = $routeKey;
- $this->exchangeType = $exchangeType;
- if(!empty($config))
- {
- $this->setConfig($config);
- }
- $this->createConnet();
- }
- //对RabbitMQ的配置重新进行配置
- public function setConfig($config)
- {
- if (!is_array($config))
- {
- throw new Exception('config不是一个数组');
- }
- foreach($config as $key => $value)
- {
- $this->config[$key] = $value;
- }
- }
- //创建连接与信道
- public function createConnet()
- {
- //创建连接
- $this->connection = new AMQPConnection($this->config);
- if(!$this->connection->connect())
- {
- throw new Exception('RabbitMQ创建连接失败');
- }
- //创建信道
- $this->channel = new AMQPChannel($this->connection);
- //创建交换机
- $this->createExchange();
- //生产时不需要队列,故队列名为空,只有消费时需要队列名
- if(!empty($this->queueName))
- {
- $this->createQueue();
- }
- }
- //创建交换机
- public function createExchange()
- {
- $this->exchange = new AMQPExchange($this->channel);
- $this->exchange->setName($this->exchangeName);
- $this->exchange->setType(AMQP_EX_TYPE_DIRECT);
- $this->exchange->setFlags(AMQP_DURABLE);
- }
- //创建队列,绑定交换机
- public function createQueue()
- {
- $this->queue = new AMQPQueue($this->channel);
- $this->queue->setName($this->queueName);
- $this->queue->setFlags(AMQP_DURABLE);
- $this->queue->bind($this->exchangeName, $this->routeKey);
- }
- public function dealMq($flag)
- {
- if($flag)
- {
- $this->queue->consume(function($envelope){$this->getMsg($envelope, $this->queue);},AMQP_AUTOACK);//自动ACK应答
- }
- else
- {
- $this->queue->consume(function($envelope){$this->processMessage($envelope, $this->queue);});
- }
- }
- public function getMsg($envelope, $queue)
- {
- $msg = $envelope->getBody();
- $this->doProcess($msg);
- }
- public function processMessage($envelope, $queue)
- {
- $msg = $envelope->getBody();
- $this->doProcess($msg);
- $queue->ack($envelope->getDeliveryTag()); //手动发送ACK应答
- }
- //处理消息的真正函数,在消费者里使用
- abstract public function doProcess($msg);
- //发送消息
- public function sendMessage($message)
- {
- $this->exchange->publish($message, $this->routeKey);
- }
- //关闭连接
- public function closeConnect()
- {
- $this->channel->close();
- $this->connection->disconnect();
- }
- }
Consum.php 如下所示
- <?php
- include_once('RabbitMqParernt.php');
- class Consum extends RabbitMqParernt
- {
- public function __construct()
- {
- parent::__construct('exchange', 'queue', 'routeKey');
- }
- public function doProcess($msg)
- {
- echo $msg;
- }
- }
- $consum = new Consum();
- //$consum->dealMq(false);
- $consum->dealMq(true);
Publish.php如下所示
- <?php
- include_once('RabbitMqParernt.php');
- class Publish extends RabbitMqParernt
- {
- public function __construct()
- {
- parent::__construct('exchange', '', 'routeKey');
- }
- public function doProcess($msg)
- {
- }
- }
test.php如下所示
- <?php
- include_once('Publish.php');
- $publish = new Publish();
- $publish->sendMessage('Hello,World!');
- $publish->closeConnect();
4、添加交换机与队列
打开http://ip(你的RabbitMQ安装的主机):15672/,会进入到RabbitMQ的可视化管理后台登录页面,登录你的账号密码(如果你是按照第一步提到的博客里的教程来装的,那你的账号密码就是guest),然后新加交换机和队列,
以下是新加交换机的操作,注意vhost与以及交换机的名称要与代码里的消费者与生产者传入的参数值保持一致,如果你不想使用"/"这个默认的vhost,也可以新建一个vhost(什么?你问我如何新建,那么请百度一下),但是要记住在代码里创建消费者与生产者时把你新加的这个vhost传进去,覆盖RabbitMqParernt.php里的vhost

以下是新加队列,这里的vhost要与上一步的vhost保持一致,保证交换机与队列在同一个vhost下,不然交换机会找不到队列的,队列名与消费者代码里传入进去的队列名保持一致

5、运行代码
然后我们在一个窗口先启动消费者

在另外一个窗口运行test.php文件

出现这个生产者发布的hello,world!就成功了

注意:消费者与生产者传入的交换机名称,路由键必须相同
交换机类型请务必选择直连,各种交换机的路由键形式不大相同,有兴趣的同学可以去试试其它类型的交换机实现哦
当修改了vhost或者交换机名称,队列名称等时,需要修改对应代码
至于注释里的ack应答,我会在之后的博客里详细介绍,包括RabbitMQ的持久化,这里使用默认的ack应答即可
对于amqp的拓展的使用,大家也可以去研究一下
关于管理后台及RabbitMQ的命令,我这里就不多介绍了,有兴趣的同学去网上搜索一下就能搜到好多
下一篇:RabbitMQ的持久化(六)
PHP中RabbitMQ之amqp扩展实现(四)的更多相关文章
- 用PHP尝试RabbitMQ(amqp扩展)实现消息的发送和接收
消费者:接收消息 逻辑:创建连接-->创建channel-->创建交换机-->创建队列-->绑定交换机/队列/路由键-->接收消息 <?php /********* ...
- windows下安装rabbitmq的php扩展amqp(原创)
从php官方下载相应的版本http://pecl.php.net/package/amqp,我这里使用的是1.4.0版本(http://pecl.php.net/package/amqp/1.4.0/ ...
- (五)RabbitMQ消息队列-安装amqp扩展并订阅/发布Demo(PHP版)
原文:(五)RabbitMQ消息队列-安装amqp扩展并订阅/发布Demo(PHP版) 本文将介绍在PHP中如何使用RabbitMQ来实现消息的订阅和发布.我使用的系统依然是Centos7,为了方便, ...
- php的amqp扩展 安装(windows) rabbitmq学习篇
因为RabbitMQ是由erlang语言实现的,所以先要安装erlang环境erlang 下载安装 http://www.erlang.org/download.htmlrabbitmq 下载安装 h ...
- centos7 安装rabbitmq rabbitmq-c以及amqp扩展 详细篇
自己鼓捣了一晚上总算整明白了,有几个坑分享给小伙伴,希望能帮到你 前期准备 安装erlang 下载rpm包地址:https://github.com/rabbitmq/erlang-rpm (注意er ...
- PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (一) -- 安装 AMQP 扩展和 Direct Exchange 模式
Windows 安装 amqp 扩展 RabbitMQ 是基于 amqp(高级消息队列协议) 协议的.使用 RabbitMQ 前必须为 PHP 安装相应的 amqp 扩展. 下载相应版本的 amqp ...
- iOS8中添加的extensions总结(四)——Action扩展
Action扩展 注:此教程来源于http://www.raywenderlich.com的<iOS8 by Tutorials> 1.准备 本次教程利用网站bitly.com进行 bit ...
- 17 个方面,综合对比 Kafka、RabbitMQ、RocketMQ、ActiveMQ 四个分布式消息队列
原文:https://mp.weixin.qq.com/s/lpsQ3dEZHma9H0V_mcxuTw 一.资料文档 二.开发语言 三.支持的协议 四.消息存储 五.消息事务 六.负载均衡 七.集群 ...
- 综合对比 Kafka、RabbitMQ、RocketMQ、ActiveMQ 四个分布式消息队列
来源:http://t.cn/RVDWcfe 一.资料文档 Kafka:中.有kafka作者自己写的书,网上资料也有一些.rabbitmq:多.有一些不错的书,网上资料多.zeromq:少.没有专门写 ...
随机推荐
- 阶段5 3.微服务项目【学成在线】_day04 页面静态化_03-freemarker测试环境搭建
新建一个module 选择parent test-freemarker spring‐boot‐starter‐freemarker:spring boot 提供的关于 freemaker的相关的包 ...
- jmeter-显示log的方法,和脚本通用的语法
beanshell log日志设置.log日志输出 步骤: 1.从选项-勾选Log Viewer,打开调试窗口 2.选择显示log的等级 3.在脚本中加入要打引的log 如: log.info(‘日 ...
- Eclipse安装Spring Tools Suites
第一种:离线安装 下载地址:较高版本 http://spring.io/tools/sts/all/ 比较低版本:http://spring.io/tools/ggts/all 选择适合自己Eclip ...
- pyCharm最新2017激活
pyCharm最新2017:下载地址 下载完成后安装软件 启动pyCharm,进入下面窗口 选择License server 在 server选项里边输入 http://elporfirio.com: ...
- 关于POW机制及POW难度调节机制
工作量证明,英文为proof of work,通过或与计算,计算出一个满足规则的随机数,即获得本次记账权,发出本轮需要记录的数据,全网其他节点验证后一起存储.简单理解就是一份证明,用来确认你做过一定量 ...
- 移植Fatfs文件系统到工程中
下载Fatfs文件管理系统:http://elm-chan.org/fsw/ff/archives.html 下载最新版本 在工程中新建Fatfs文件夹,把fatfs文件中的全部复制过来 由于Fatf ...
- elasticsearch 的post put 方式的对比 setting mapping设置 - 添加查询数据
1.POST和PUT都可以用于创建 2.PUT是幂等方法,POST不是.所以post用户更新,put用于新增比较合适. 参考:https://yq.aliyun.com/articles/366099 ...
- Python用摘要算法生成token及检验token
原创作者:希希大队长,blog:https://cnblogs.com/dongxixi/ # 基础版,不依赖环境 import time import base64 import hashlib c ...
- Nginx 小入门记录 之 Nginx 配置文件解读(二)
上一小节主要是记录一些环境准备和Nginx的安装,接下来对Nginx基本配置进行记录. 查看配置文件安装记录 可以通过以下Linux命令进行查看: rpm -ql nginx rpm 是liunx的包 ...
- windows远程重启
用管理员权限打开win+r,输入cmd后: net use \ip地址 "管理员密码" /user:administrator shutdown /r /t 0 /m ip地址 即 ...