rabbitmq入门(rabbitmq菜鸟教程)

一、前言

刚开始接触RabbitMQ的时候,有些概念那理解起来简直是像风像雨又像雾,晦涩难懂。

这篇文章用尽可能浅显的语言来解释RabbitMQ的入门知识。毕竟是入门课程,并没有对很多概念进行深入说明,如果你想更深入的了解RabbitMQ,可以继续关注本头条号后续发布的文章或者自己从网上搜寻了资料,自己探索研究。

二、RabbitMQ是什么

官方定义:RabbitMQ是一种消息中间件,用于处理来自客户端的异步消息。服务端将要发送的消息放入到队列池中。接收端可以根据RabbitMQ配置的转发机制接收服务端发来的消息。RabbitMQ依据指定的转发规则进行消息的转发、缓冲和持久化操作,主要用在多服务器间或单服务器的子系统间进行通信,是分布式系统标准的配置。

趣味定义:兔子行动非常迅速而且繁殖起来也非常疯狂,用Rabbit来命名这个分布式软件,呼应了RabbitMQ的主要任务是处理海量的信息

三、安装

1、安装erlang

下载地址:
       http://erlang.org/download/otp_win64_21.0.1.exe

2、安装rabbitmq

下载地址:
       https://dl.bintray.com/rabbitmq/all/rabbitmq-server/3.7.7/rabbitmq-server-3.7.7.exe

如果你要安装其它版本,注意版本对应:
       https://www.rabbitmq.com/which-erlang.html

3、开启web访问

Windows下:打开CMD

进入rabbitmq的安装目录

执行rabbitmq-plugins enable rabbitmq_management命令

该命令,仅在首次运行RMQ时使用!!!目的就是加载Web插件!!!

4、浏览器访问:http://localhost:15672/

默认用户名:guest

默认密码:guest

四、核心概念

https://content.pivotal.io/rabbitmq/understanding-when-to-use-rabbitmq-or-apache-kafka

RabbitMQ broker,原话是RabbitMQ isn’t a food truck, it’s a delivery service,其实说白了,就是一种传输服务。

Exchange: 接受生产者发送的消息,并根据Binding规则将消息路由给服务器中的队列。ExchangeType决定了Exchange路由消息的行为。在RabbitMQ中,ExchangeType常用的有direct、Fanout和Topic三种,在第三部分会详细介绍。

Message Queue: 消息队列。我们发送给RabbitMQ的消息最后都会到达各种queue,并且存储在其中(如果路由找不到相应的queue则数据会丢失),等待消费者来取。

Binding Key:它表示的是Exchange与Message Queue是通过binding key进行联系的,这个关系是固定的,初始化的时候,我们就会建立该队列。

Routing Key:生产者在将消息发送给Exchange的时候,一般会指定一个routing key,来指定这个消息的路由规则。这个routing key需要与Exchange Type及binding key联合使用才能生,我们的生产者只需要通过指定routing key来决定消息流向哪里。

我的注释:初始化的时候,exchange与各个队列的绑定关系是通过binding key进行绑定的;发送消息的时候,使用的routing key就是binding key的某一个(实质,两者是一个含义,角度不同,名称含义不同)

对于消费端来说,只用知道MQ的virtual host 和queue的名称就可以了。而对于发送端,则需要知道exchange和routing key的名称,相对而言queue的名称就不那么重要了(不过也要依Exchange Type而定)。

以下是RabbitMQ最简单的流程图,相信看到这里的你,对MQ的运作流程应该会有个基本的了解了:

五、三种ExchangeType

http://www.rabbitmq.com/tutorials/amqp-concepts.html

这里介绍三种最主要的类型的exchange:direct、fanout和topic。

1、direct交换器

Direct交换器很简单,如果是Direct类型,就会将消息中的RoutingKey与该Exchange关联的所有Binding中的BindingKey进行比较,如果相等,则发送到该Binding对应的Queue中。有一个需要注意的地方:如果找不到指定的exchange,就会报错。但routing key找不到的话,不会报错,这条消息会直接丢失,所以此处要小心

2、fanout交换器

Fanout 扇出,顾名思义,就是像风扇吹面粉一样,吹得到处都是。如果使用fanout类型的exchange,那么routing key就不重要了。因为凡是绑定到这个exchange的queue,都会受到消息。

3、topic交换器

direct是将消息放到exchange绑定的一个queue里(一对一);

fanout是将消息放到exchange绑定的所有queue里(一对所有)

那可不可以把消息放到exchange绑定的一部分queue里,或者多个routing key可以路由到一个queue里呢?

topic类型的exchange就可以实现(一对部分)。

topic应用场景:打印不同级别的错误日志

例如,我们的系统出错后会根据不同的错误级别生成error_levelX.log日志,我们在后台首先要把所有的error保存在一个总的queue(绑定了一个*.error的路由键)里,然后再按level分别存放在不同的queue。

routing key绑定如下图:

进阶攻略:RabbitMQ进阶攻略,分析RabbitMQ的典型应用场景,详解其运作流程

(0)

相关推荐

  • python小白入门(python基础教程菜鸟教程)

    本文涉及的python基础语法为:数据类型等数据类型1. 字符串的拼接我们在上一章中已经简单介绍了一下字符串的创建方式,这里我们简单学习一下字符串的运算和拼接.字符串的运算`字符串的加法` #把字符串 ...

  • Android基础入门教程(android菜鸟教程)

    不知从什么时候起,网上出现了一种奇怪的论调,说安卓手机用久了,就会越来越慢,而iPhone则会一直保持流畅.大家似乎认为这是一条不需论证的公理,由此推导出iOS优于Android的结论.基本事实是,如 ...

  • swift可以开发程序给苹果手机用吗(swift菜鸟教程)

    Swift 是苹果公司于2014年发布的编程语言,它强大而直观,适用于 macOS.iOS.watchOS 和 Apple tvOS 等平台软件的开发.Swift 语法简洁.表现力强,由于它非常的年轻 ...

  • pytorch菜鸟教程(pytorch 教程)

    来源:图灵社区        题图来自Usplash1 什么是PyTorch?PyTorch是与TensorFlow.MXNet.Caffe等平行的深度学习开源框架.2017年初由Facebook首次 ...

  • 摄影技术与技巧(摄影入门基础知识教程)

    注:1.本入门手册只能作为一个大致的参考,艺术(或者我们暂时都还只能叫技术)都是在学习惯例和不断突破惯例中成长的,希望大家不要太拘束于我讲的这些不一定正确的规则_(:з)∠)_2.由于我自己目前使用的 ...

  • UG8.0从入门到精通教程

    UG是机械设计从业者经常使用额软件之一,如何学习此款软件呢?怎样才能从入门学到精通呢?以下我学习UG软件的,供大家参考. 操作方法 01 第一步,学习草绘.草绘里面的命令全部要熟悉,,包括插入里面的命 ...

  • AI入门基础工具教程视频

    AI在矢量图形设计方面的功能是非常强大的,在做矢量图形设计时常常会使用到该软件,下面我们就来看看AI是如何入门的吧. 操作方法 01 将AI这款软件打开之后,在最上面就可以找到菜单栏,在这里我们就可以 ...

  • 菜鸟教程之电脑必备常识集合

    对于菜鸟用户来说当务之急就是好好的学习下关于电脑方面的一些必备常识,这样才能为自己电脑水平的提升大号基础.电脑硬件必须知道的几个常识的详细介绍如下: 操作方法 01 1:显示器无反应.多数都是内存导致 ...

  • PowerPoint入门:图片美化教程

    图片变脸,轻松又好玩: 在使用PPT2007的时候,首先应当改掉以前去菜单中一个个找自己需要功能的习惯。大家注意每步操作的界面变化,随着你的操作的变化,所有你需要的功能都直接摆在了你的面前。你只需要选 ...

  • html教程菜鸟教程(HTML基础必备知识点)

    一.网页1.网站是网页的集合,网页是构成网站的基本元素,是由图片.链接.文字.声音.视频等元素组成的HTML格式文件.2.HTML是超文本标记语言(Hyper Text Markup Language ...