刚开始接触RabbitMQ的时候,有些概念那理解起来简直是像风像雨又像雾,晦涩难懂。 这篇文章用尽量浅显的语言来解释RabbitMQ的入门知识。毕竟是入门课程,并无对不少概念进行深刻说明,若是你想更深刻的了解RabbitMQ,能够继续关注本头条号后续发布的文章或者本身从网上搜寻了资料,本身探索研究。html
官方定义:RabbitMQ是一种消息中间件,用于处理来自客户端的异步消息。服务端将要发送的消息放入到队列池中。接收端能够根据RabbitMQ配置的转发机制接收服务端发来的消息。RabbitMQ依据指定的转发规则进行消息的转发、缓冲和持久化操做,主要用在多服务器间或单服务器的子系统间进行通讯,是分布式系统标准的配置。 趣味定义:兔子行动很是迅速并且繁殖起来也很是疯狂,用Rabbit来命名这个分布式软件,呼应了RabbitMQ的主要任务是处理海量的信息web
下载地址:http://erlang.org/download/otp_win64_21.0.1.exeapache
下载地址:https://dl.bintray.com/rabbitmq/all/rabbitmq-server/3.7.7/rabbitmq-server-3.7.7.exe 若是你要安装其它版本,注意版本对应:https://www.rabbitmq.com/which-erlang.html服务器
Windows下:打开CMD 进入rabbitmq的安装目录 执行rabbitmq-plugins enable rabbitmq_management命令 该命令,仅在首次运行RMQ时使用!!!目的就是加载Web插件!!! 异步
默认用户名:guest 默认密码:guest 分布式
https://content.pivotal.io/rabbitmq/understanding-when-to-use-rabbitmq-or-apache-kafka测试
如下是RabbitMQ最简单的流程图,相信看到这里的你,对MQ的运做流程应该会有个基本的了解了: 插件
http://www.rabbitmq.com/tutorials/amqp-concepts.html 这里介绍三种最主要的类型的exchange:direct、fanout和topic。3d
Direct交换器很简单,若是是Direct类型,就会将消息中的RoutingKey与该Exchange关联的全部Binding中的BindingKey进行比较,若是相等,则发送到该Binding对应的Queue中。有一个须要注意的地方:若是找不到指定的exchange,就会报错。但routing key找不到的话,不会报错,这条消息会直接丢失,因此此处要当心。日志
Fanout 扇出,顾名思义,就是像风扇吹面粉同样,吹获得处都是。若是使用fanout类型的exchange,那么routing key就不重要了。由于凡是绑定到这个exchange的queue,都会受到消息。
routing key绑定以下图:
更多资料分享,问题咨询,能够入群讨论:375412858 请入群索要代码