kbigbus / php_rabbitmq_test

测试rabbitmq的相关特性

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

php_rabbitmq_test

利用PHP的amqp扩展 测试rabbitmq的相关特性
rabbitmq 服务端 3.3.3
amqp 版本 1.2.0 / php-amqplib 版本 2.5.* (两种客户端的区别)
主要介绍客户端的操作情况,服务端安装过程请自行搜索安装。(有很多坑)
php-amqplib 范例皆参考于官网 http://www.rabbitmq.com/getstarted.html

rabbitmqctl 命令操作

参见官方文档 http://previous.rabbitmq.com/v3_3_x/man/rabbitmqctl.1.man.html

坑爹问题记录 出现问题查日志 (默认路径 /var/log/rabbitmq/rabbitmq*******)

1/ amqp_error,access_refused, "PLAIN login refused: user 'xxxx' - invalid credentials",

出现这个问题是因为当前登陆的用户没有 vhost(默认是/)的权限,即便是管理员也需要先通过 rabbitmqctl set_permissions user "." "." ".*" 命令来设置权限

2/ PHP Fatal error: Uncaught exception 'PhpAmqpLib\Exception\AMQPProtocolChannelException' with message 'PRECONDITION_FAILED - parameters for queue 'hello' in vhost '/' not equivalent' in /mnt/hgfs/GIT/php_rabbitmq_test/vendor/php-amqplib/php-amqplib/PhpAmqpLib/Channel/AMQPChannel.php:191

这是由于测试时另一个脚本用了 hello 这个队列导致的,改另一个名就行了。 补上网络上的解答(一般原因:建立channel或queue的参数不同。特别是declare已有的同名queue时容易出现此错误。解决办法:删除rabbitmq-server上相应的queue,重新建立)

队列处理说明(p producer生成者 c consumer消费者)

简单队列 simple

一一对应关系 设置好对应的routekey 1p to 1c

多消费 workqueue

1p to Nc 一个生成者对应多个消费者, 需要确认的问题有
1、多进程的消息分配问题(rabbitmq自己解决)
2、消息丢失恢复问题(一个消费者处理过程中挂掉了,保证当前这条消息能恢复处理。消息确认机制(ack/nack))
3、rabbitmq 服务器挂掉(消息持久化durable,能解决大部分问题。 If you need a stronger guarantee then you can use publisher confirms.)
4、多条复杂任务分配给一个c,多条简单任务分配给一个c。造成一个很忙一个很闲(消息公平调度,AMQPChannel::qos)

订阅 / 广播 subscribe

1、申明exchange的类型为 fanout
2、无需指定queue
3、消费者 可随机获取或自定义 queue, 确定queue与 exchange绑定关系即可
4、消费者不在线 广播将无法送达!!!
5、无 route-key 绑定关系

路由 route

1、申明exchange的类型为 direct
2、生成者 publish消息到对应的 route-key
3、消费者 通过route-key 绑定 queue 与 exchange

主题 topic

与route 操作一致,只是route-key 可以做匹配 (多个词以 . 隔开,代表一个词,#代表0个或多个词)
route-key 设置为 #,可替换 subscribe, route-key 设置为无
#的字符 可替换route

rpc

利用中转队列rpc_queue

总结

1、simple/workqueue 没有exchange概念 直接通过 queue操作
2、subscribe/route 都是通过route-key 绑定 queue 与 exchange
3、需要绑定的处理 必须消费者在线的情况下才能收到消息(即publish是客户端必须在运行状态) 否则消息会丢失
4、exchange可以绑定多个route-key,即可以一条客户端下接收多个queue的数据

About

测试rabbitmq的相关特性


Languages

Language:PHP 100.0%