PHP中使用RabiitMQ---各项参数的使用方法
RabbitMQ在PHP使用,我在这里对RabbitMQ的各项方法和参数进行了一些梳理,有不足的地方还望各位大神指点. 想要使用rabbitMQ消息队列,首先需要安装 php_amqp.dll 扩展 和 rabbitMQ 服务, 至于怎么安装大家可以百度一下,这类的资料还是有很多的.
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
RabbitMQ的工作原理大概如下:
生产者:生产消息--->创建交换器:对消息进行routekey鉴别,然后分发到相对应的队列---->队列:通过routekey,装载消息,然后运输给消费者-->消费者:接收队列传送的消息,进行处理,然后给予回应.
下面是RabbitMQ生产者实现的简单代码:
<?php
$exchangeName = 'ceshi1';
$queueName = 'ceshi_queue1';
$str = 'ceshi'.rand(1,9999);
$routeKey = 'ceshi_queue1';
$message = $str; $connection = new AMQPConnection(array('host' => '', 'port' => '', 'vhost' => '', 'login' => '', 'password' => ''));
$connection->connect() or die("Cannot connect to the broker!\n"); # 连接服务
$channel = new AMQPChannel($connection);
# 创建交换器
$exchange = new AMQPExchange($channel);
# 设置交换器的名称
$exchange->setName($exchangeName);
# 设置多个参数值[setArguments ( array $arguments )];
# 获取该队列某个参数的信息 , getArgument ( string $key )
# [如果无法将此交换机的消息路由,则将它们发送到这里指定的备用交换机。(设置“alternate-exchange”参数)。]
# 设置交换器类型
# AMQP_EX_TYPE_DIRECT[点对点],AMQP_EX_TYPE_FANOUT[广播],AMQP_EX_TYPE_TOPIC[模糊匹配],AMQP_EX_TYPE_HEADER[头匹配]
$exchange->setType(AMQP_EX_TYPE_DIRECT);
# 交换器持久化
//$exchange->setFlags(AMQP_DURABLE);
# 执行创建交换器
$exchange->declareExchange();
# 创建队列
$queue = new AMQPQueue($channel);
$queue->setName($queueName);
# 设置单个指定的参数键值,setArgument ( string $key , mixed $value )
# 获取该队列某个参数的信息 , getArgument ( string $key )
//$queue->setArgument();
# [发布到队列中的消息可以在被丢弃之前生存多长时间(毫秒(设置x-message-ttl)参数。]
# [在自动删除队列(毫秒)之前,该队列不能被使用多长时间。(设置“x-expires”参数)。]
# [队列中有多少(准备好的)消息[个数],可以在它开始,从其头上删除之前包含。(设置x-max-length长度)参数]
# [准备好的消息的总大小,队列可以在它开始从头上删除之前包含。(设置x-max-length-bytes 纵向字节)参数]
# [如果拒绝或过期消息将被重新发布的Exchange的可选名称。(设置“x-dead-letter-exchange”参数,[交换器名,(string)])。]
# [可选的替换路由密钥,当消息已被写入字母时使用。如果未设置此消息,将使用消息的原始路由密钥。(设置“x-dead-letter-routing-key”参数)。]
# [支持队列的最大优先级数量;如果未设置,队列将不支持消息优先级。(设置x-max-priority)参数。]
# [将队列设置为懒惰模式,尽可能保留磁盘上的尽可能多的消息以减少RAM的使用;如果没有设置,队列将保持内存中的缓存以尽可能快地传递消息。(设置“x-queue-mode”参数设置:lazy)。]
# [将队列设置为主定位模式,确定在节点群集上声明队列主控器所处的规则。(设置x-queue-master-locator 参数。]
# 设置多个参数值[setArguments ( array $arguments )];
# 获取该队列所有参数的信息 , getArguments ( void )
//$queue->setArguments();
# 持久化队列
# AMQP_DURABLE[队列持久], AMQP_PASSIVE[返回消息计数], AMQP_EXCLUSIVE[只被一个连接(connection)使用,而且当连接关闭后队列即被删除], AMQP_AUTODELETE[当最后一个消费者退订后即被删除].
$queue->setFlags(AMQP_DURABLE);
# 执行创建队列
$queue->declareQueue(); # 开启事务,确保数据真正不丢失
$channel->startTransaction();
# 将消息和标识绑定到交换器中
# publish(message[消息],route_key,[ flags[ AMQP_MANDATORY,AMQP_IMMEDIATE],attributes[array] ]);
# attributes 存有参数 => [content_type(用于描述MIME类型的编码。例如,对于经常使用的JSON编码,将此属性设置为 “application/json” 是一个很好的做法。),
#content_encoding,message_id,user_id,app_id,delivery_mode[2 消息持久,1非持久],priority,timestamp,expiration,type,reply_to(主要用于命名一个回调队列 ) ]
$exchange->publish($message,$routeKey);
$channel->commitTransaction();
var_dump("[x] Sent $message"); # 关闭连接
$connection->disconnect(); ?>
以上是生产者的简单代码,下面我们可以看看消费者的简单代码:
<?php
$exchangeName = 'ceshi1';
$queueName = 'ceshi_queue1';
$routeKey = 'ceshi_queue1'; $connection = new AMQPConnection(array('host' => '', 'port' => '', 'vhost' => '', 'login' => '', 'password' => ''));
$connection->connect() or die("Cannot connect to the broker!\n"); # 连接服务
$channel = new AMQPChannel($connection);
$exchange = new AMQPExchange($channel);
$exchange->setName($exchangeName);
# 设置交换器类型
$exchange->setType(AMQP_EX_TYPE_DIRECT);
# 交换器持久化
//$exchange->setFlags(AMQP_DURABLE);
$exchange->declareExchange(); $queue = new AMQPQueue($channel);
$queue->setName($queueName);
$queue->setFlags(AMQP_DURABLE);
$queue->declareQueue(); # 队列根据routekey 装载消息
$queue->bind($exchangeName,$routeKey);
var_dump('[*] Waiting for messages. To exit press CTRL+C');
#
$queue->consume('callback');
# 设置每次只能处理一条,避免消息堆积,从而导致队列挂掉
$channel->qos(0,1);
#关闭连接
$connection->disconnect(); function callback($envelope, $queue) {
$msg = $envelope->getBody();
// var_dump(" [x] Received:" . $msg);
echo $msg."\n";
// # nack 让没有通过的消息可以 再次进入队列, ack 没有通过的消息不能再次回到队列中
// # 通知队列消息通过,可以执行下一个消息
$queue->nack($envelope->getDeliveryTag());
}
?>
这些代码都是在网上收集的,我个人在附加了一些方法和参数的使用方法,希望能帮到各位,谢谢!!!!
PHP中使用RabiitMQ---各项参数的使用方法的更多相关文章
- VS2013中带命令行参数的调试方法---C++
今天先记录一下(也是传说中大神喜欢装逼的comment line)c++中向主函数int main(int argc,char** argv )传递4中方法,欢迎添加新方法, 然后可以参考别人写的很好 ...
- <django中render_to_response的可选参数和使用方法>
在django官方文档中有比较详细的介绍,在此我按照自己的理解适当的阐述一下: return render_to_response(①'my_template.html', ②my_data_dict ...
- 【Java学习笔记之二十七】Java8中传多个参数时的方法
java中传参数时,在类型后面跟"..."的使用: public static void main(String[] args){ testStringA ...
- MySQL中limit使用动态参数的解决方法(拼接SQL字符串语句来执行SQL)
官方好像说过limit已经在5.6版本上支持了动态参数,但是测试时依然还是不行. 那么要解决limit动态参数唯一能做的就是使用字符串SQL拼接的形式,然后再进行执行. 一般有以下方式解决: 1.存储 ...
- 织梦后台系统设置在PHP5.4环境中不能保存中文参数的解决方法
在没用PHP5.4的环境做Dede后台的时候,织梦58一直没有遇到这个问题,昨天上传一个新的模版到空间去测试发现后台的系统基本参数设置中所有的中文内容都无法保存,关于这个问题,其实以前也听说过,知识一 ...
- vue v-show与v-for同时配合v-bind使用并在href中传递多个参数的使用方法
最近在项目中,因为还没使用前端构建工具,还在使用vue+jquery方法渲染页面 碰到几个小问题,在此记录下作为vue学习之路上的一个小知识点 需求:1.数据列表存在与否状态,没有数据显示默认提示,有 ...
- .net中MVC Webapi多参数调用控制器方法
http://blog.csdn.net/wulex/article/details/71545471 路由 public static void Register(HttpConfiguration ...
- sql 解析字符串添加到临时表中 sql存储过程in 参数输入
sql 解析字符串添加到临时表中 sql存储过程in 参数输入 解决方法 把字符串解析 添加到 临时表中 SELECT * into #临时表 FROM dbo.Func_SplitOneCol ...
- 细说javascript 中的 window.open() 参数设置
今天遇到一个问题,就是要用javascript中的window.open()打开一个新的网页,而且新打开的网页要在原来网页的基础之上,在查了一些资料之后,找到里一下方法:(其中,url 为链接的地址) ...
随机推荐
- iOS设计模式 - 原型
iOS设计模式 - 原型 原理图 说明 1. 原型模式指的是从一个已有的对象复制并创建出新的对象 2. 当一个类的实例之间存在差异,而这些差异仅是状态的若干组合,复制原型要比手工实例化更加方便 3. ...
- [翻译] JTBorderDotAnimation
JTBorderDotAnimation https://github.com/jonathantribouharet/JTBorderDotAnimation JTBorderDotAnimatio ...
- oracle中RAW数据类型
近日在研究v$latch视图时,发现一个从未见过的数据类型.v$latch 中ADDR属性的数据类型为RAW(4|8) 同时也发现v$process中的ADDR属性的数据类型也为RAW(4|8).于 ...
- Angular实现多标签页效果(路由重用)
1.需求 做了几年的MES系统,从ASP.NET WebForm至MVC,系统决定了用户界面必须为标签页方式实现,因为用户在进行一项操作的时候很有可能会进行其它的操作,比如查询之类的.如果按MVC的方 ...
- December 17th 2016 Week 51st Saturday
Great minds have purpose, others only have wishes. 杰出的人有着目标,其他人只拥有愿望. Are you clear about the differ ...
- codeforces 932E Team Work(组合数学、dp)
codeforces 932E Team Work 题意 给定 \(n(1e9)\).\(k(5000)\).求 \(\Sigma_{x=1}^{n}C_n^xx^k\). 题解 解法一 官方题解 的 ...
- python时间模块和random模块
模块:用一坨代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能,可能需要多个函数才能 ...
- wireshark:no interface can be used for capturing in this system with the current configuration
在虚拟机unbuntu中,进行wireshark抓包,出现:no interface can be used for capturing in this system with the current ...
- 【[SHOI2007]善意的投票】
直接是最小割啊 设最终还和\(S\)相连表示睡觉,和\(T\)相连表示不睡觉 如果这个人想睡觉,那么就从源点向它连\(1\)的边,表示割掉这条边选择不睡觉的代价为1 如果这个人不想睡觉的话,就向汇点连 ...
- 包不包含__declspec(dllimport)的判定
按照MSDN说明,当链接dll的导出函数时,只需要包含头文件和lib,__declspec(dllimport)修饰符不是必须的,但加上该修饰能使导出函数的调用效率更高.那么,究竟原因是什么? 不使用 ...