RabbitMQ 初体验
概述
RabbitMQ是一款消息队列中间件。他提供了几乎覆盖所有语言的SDK与文档,简直强大的不的了。要详细的去了解学习RabbitMQ,我建议还是看官方文档吧。http://www.rabbitmq.com/getstarted.html
消息队列有以下几个基本用途
- 异步处理
- 应用解耦
- 流量削峰
- 系统架构
消息队列的这几个用途我会在后续的文章以真实案例去表述
生产者
创建RabbitMQ链接
1 | $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); |
与链接一个数据库概念差不多
创建一个队列声明
1 | $channel->queue_declare ('hello'); |
创建多个队列与创建多个数据库一样,hello则是队列名
创建一条消息到队列
1 | $message = new AMQPMessage('Hello World!'); |
发布消息到队列
1 | $channel->basic_publish ($message, '', 'hello'); |
hello 是上面创建的队列声明
关闭链接
1 | $channel->close (); |
释放资源
消费者
创建RabbitMQ链接
1 | $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); |
与链接一个数据库概念差不多
创建一个队列声明
1 | $channel->queue_declare ('hello'); |
创建多个队列与创建多个数据库一样,hello则是队列名
消费
1 | $channel->basic_consume ('hello', '', false, true, false, false, function ($msg) { |
通过回调函数处理消息队列
等待
1 | while (count ($channel->callbacks)) { |
无消息时,挂起保持等待状态
关闭链接
1 | $channel->close (); |
释放资源
完整的案例
完整的按钮则是上面所有代码的整理
生产者
1 | $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); |
消费者
1 | $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); |
执行
1 | php {生产者}.php |
其他
RabbitMQ支持多线程处理消息队列,所有你可以开启多个消费者去执行消息队列内的任务。你可以像我这样
如果你感觉RabbitMQ这玩意还需要安装啥的感觉特麻烦,那你可以看下我的Laravel队列如何简单的玩起来。
https://segmentfault.com/a/1190000010604659
致谢
感谢你看完我这篇文章,纯手记的一篇文章,官方文档对新手的理解造成很多的误解,所以整理此文档,尽量避免新手“进”坑吧。对文章有什么问题或疑问,欢迎在评论区留言。谢谢
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 CrazyCodes!