消息队列

此处使用window环境,Linux环境下,添加

资源URL

概念

几个概念说明:

Broker:简单来说就是消息队列服务器实体。

Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

Queue:消息队列载体,每个消息都会被投入到一个或多个队列。

Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。

Routing Key:路由关键字,exchange根据这个关键字进行消息投递。

vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。

producer:消息生产者,就是投递消息的程序。

consumer:消息消费者,就是接受消息的程序。

channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。

消息队列的使用过程大概如下:

(1)客户端连接到消息队列服务器,打开一个channel。

(2)客户端声明一个exchange,并设置相关属性。

(3)客户端声明一个queue,并设置相关属性。

(4)客户端使用routing key,在exchange和queue之间建立好绑定关系。

(5)客户端投递消息到exchange。

exchange接收到消息后,就根据消息的key和已经设置的binding,进行消息路由,将消息投递到一个或多个队列里。

exchange也有几个类型,完全根据key进行投递的叫做Direct交换机,例如,绑定时设置了routing key为”abc”,那么客户端提交的消息,只有设置了key为”abc”的才会投递到队列。对key进行模式匹配后进行投递的叫做Topic交换机,符号”#”匹配一个或多个词,符号””匹配正好一个词。例如”abc.#”匹配”abc.def.ghi”,”abc.”只匹配”abc.def”。还有一种不需要key的,叫做Fanout交换机,它采取广播模式,一个消息进来时,投递到与该交换机绑定的所有队列。

RabbitMQ支持消息的持久化,也就是数据写在磁盘上,为了数据安全考虑,我想大多数用户都会选择持久化。消息队列持久化包括3个部分:

(1)exchange持久化,在声明时指定durable => 1

(2)queue持久化,在声明时指定durable => 1

(3)消息持久化,在投递时指定delivery_mode => 2(1是非持久化)

如果exchange和queue都是持久化的,那么它们之间的binding也是持久化的。如果exchange和queue两者之间有一个持久化,一个非持久化,就不允许建立绑定。

安装环境

先安装erlang包,然后添加环境变量 PATH erlang安装路径\bin

然后安装rabbitMQ,然后添加环境变量 PATH rabbitMQ安装路径\sbin

以管理员身份进入rabbitMQ安装目录/sbin依次执行命令

rabbitmq-plugins.bat enable rabbitmq_management

rabbitmq-service.bat stop

rabbitmq-service.bat install

rabbitmq-service.bat start

执行后,访问127.0.0.1:15672 查看rabbitMQ是否安装成功, 登录账号密码是 guest

PHP环境搭建

配置 php.ini extension=php_amqp.dll; 并将rabbitmq.*.dll 放到和php.ini的同级目录下

重启php-fpm

打印phpinfo() 查看amqp扩展

安装END

customer.php

$conn_args = [

'host' => '127.0.0.1',

'port' => '5672',

'login' => 'guest',

'password' => 'guest',

'vhost' => '/',

];

$exchangeName= 'exchange'; #交换机名

$queueName = 'queue'; #队列名

$keyRoute = 'keyRoute'; #路由key

//创建链接

$conn = new AMQPConnection($conn_args);

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

die('连接失败');

}

//创建频道

$channel = new AMQPChannel($conn);

//创建交换机

$exchange = new AMQPExchange($channel);

$exchange->setName($exchangeName); #交换机名

$exchange->setType(AMQP_EX_TYPE_DIRECT); #类型

$exchange->setFlags(AMQP_DURABLE); #持久化

echo "交换机状态:".$exchange->declareExchange()."\n";

//创建队列

$queue = new AMQPQueue($channel);

$queue->setName($queueName);

$queue->setFlags(AMQP_DURABLE); #持久化

echo "消息总数:".$queue->declareQueue()."\n";

//绑定交换机与队列,并指定路由键

$queue->bind($exchangeName, $keyRoute);

//阻塞模式接收消息

echo "Message:\n";

while(True){

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

$msg = $envelope->getBody();

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

$queue->ack($envelope->getDeliveryTag()); //手动发送ACK应答

});

//$queue->consume('processMessage', AMQP_AUTOACK); //自动ACK应答

}

$conn->disconnect();

publisher.php

$conn_args = array(

'host' => '127.0.0.1',

'port' => '5672',

'login' => 'guest',

'password' => 'guest',

'vhost' => '/'

);

$exchangeName = 'exchange'; //交换机名

$keyRoute = 'keyRoute'; //路由key

//创建连接和channel

$conn = new AMQPConnection($conn_args);

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

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

}

$channel = new AMQPChannel($conn);

date_default_timezone_set("Asia/Shanghai");

//创建交换机对象

$exchange = new AMQPExchange($channel);

$exchange->setName($exchangeName);

$exchange->setType(AMQP_DURABLE);

//发送消息

//$channel->startTransaction(); //开始事务

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

sleep(1);//休眠1秒

//消息内容

$message = "测试数据!" . date("H:i:s");

echo "Send Message:" . $exchange->publish($message, $keyRoute) . "\n";

}

//$channel->commitTransaction(); //提交事务

$conn->disconnect();

命令行A下先执行 php customer.php,然后新cmd下执行 php publisher.php

命令行A将有输出

rabbimq与PHP,PHP初次使用rabbitMQ相关推荐

  1. ACCESS_REFUSED - Login was refused using authentication mechanism PLAIN. For details see the broker

    初次接触 RabbitMQ 出现问题 使用 springboot 集成 RabbitMQ 启动时出现问题 pom.xml <parent><groupId>org.spring ...

  2. 初次在Linux CentOS上安装RabbitMQ

    RabbitMQ简介 RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件). RabbitMQ服务器是用Erlang语言编写的,而群集和故障转移是构建在开放电 ...

  3. celery的初次使用

    celery的初次使用 基本步骤: 选择并且安装一个消息中间件(Broker) 安装 Celery 并且创建第一个任务 运行职程(Worker)以及调用任务 跟踪任务的情况以及返回值 应用 创建第一个 ...

  4. 关于RabbitMq你必须深入理解的内容

    关于RabbitMq你必须深入理解的内容 前言 这里主要想整理关于消息队列rabbitmq可能遇到问题,躺一躺其中的坑,然后在团队沉淀下来,最终变为整个团队的技术能力,然后写着写着发现,官方文档写的都 ...

  5. Python全栈开发:RabbitMQ/Redis/Memcache/SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  6. RabbitMQ基本概念

    AMQP 和IM的区别: AMQP: 1.可以一对多广播,也可以一对一广播 2.生产者和消费者不知道对方是谁 IM: 1.只能一对一广播 2.生产者和消费者知道对方是谁 RabbitMQ:只是消息代理 ...

  7. springboot + rabbitmq 整合示例

    几个概念说明: Broker:简单来说就是消息队列服务器实体. Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列. Queue:消息队列载体,每个消息都会被投入到一个或多个队列. B ...

  8. 消息队列之RabbitMQ

    知识预览 RabbitMQ 回到顶部 RabbitMQ 什么叫消息队列 消息(Message)是指在应用间传送的数据.消息可以非常简单,比如只包含文本字符串,也可以更复杂,可能包含嵌入对象. 消息队列 ...

  9. RabbitMQ原理讲解

    我们来看RabbitMQ的原理介绍,现在大家看到的这个图呢,其实就是通过图形方式,表达了RabbitMQ的原理结构图,先不着急看第二个图,先来看第一个,其实这个图介绍了RabbitMQ一个消息的提供者 ...

最新文章

  1. Samsung:Galaxy Fold确认解决屏幕问题
  2. django 的ORM
  3. 对称加密和不对称加密原理
  4. 算法的时间和空间复杂度
  5. php 换行 PHP_EOL变量
  6. MyEclipse配置Tomcat 6
  7. Win11系统如何设置任务栏新消息提醒
  8. the android sdk location cannot be at the filesystem root
  9. python依赖注入_什么是依赖注入?
  10. ppt转pdf软件免费版
  11. linux系统初始化脚本
  12. 64位和32位的寄存器和汇编的比较
  13. 基于web的仿Steam游戏网
  14. kasp技术原理_基因型鉴定的多种方法
  15. php fatal 和php error,从PHP Fatal error: Uncaught Error: Class '' not found in php:说起
  16. Java - constants
  17. 浅谈Linux PMIC驱动(一)
  18. 蚂蚁金服Java面试题、笔试题(含答案)-中级
  19. input不为空,且返回焦点
  20. SQLI DUMB SERIES-10

热门文章

  1. 关于学习过程中走过的弯路
  2. ENBM内部测试试题 组建与维护企业网络试题
  3. [C/C++标准库]_[初级]_[优先队列priority_queue的使用]
  4. 浅谈Android组件化
  5. 如何提取cocos iOS应用程序APP与游戏安装包里的资源与文件
  6. Windows下程序打包发布时的小技巧
  7. 大恶人吉日嘎拉之走火入魔闭门造车之.NET疯狂架构经验分享系列之(一)后台控制逻辑代码部分...
  8. SES机箱管理知识回顾(二) 之SAF-TE简介
  9. php 自学 经验,学习PHP:PHP学习的几个问题经验总结
  10. 检测到你的手机处于root环境_选择群控系统的注意事项!繁星云手机盒子会比群控更合适好用吗!...