RabbitMQ面试必备知识点及实战(二)-核心概念(上)

简介: RabbitMQ面试必备知识点及实战(二)-核心概念(上)

1 为什么使用 RabbitMQ

开源的消息代理和队列服务器,通过普通协议在完全不同的应用间共享数据,使用Erlang语言编写,并且基于AMQP协议。

据报道,滴滴、美团、头条、去哪儿、艺龙…都选择了它:

  • 开源,性能优秀,稳定性有保障
  • 提供可靠性消息投递模式(confirm),返回模式(return)
  • 与Spring AMQP完美整合,API丰富
  • 集群模式丰富,表达式配置,HA模式,镜像队列模型
  • 保证数据不丢失的前提做到高可靠性、可用性


2 高性能之源

  • Erlang语言
    最初在于交换机领域的架构模式,这样使得RabbitMQ在Broker之间进行数据交互的性能非常优秀
  • Erlang的优点
    Erlang有着和原生Socket一样的延迟

3 AMQP协议

AMQP,Advanced Message Queuing Protocol,高级消息队列协议。

一个提供统一消息服务的应用层标准的二进制的高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于该协议的客户端与消息中间件可传递消息,并不受客户端/中间件同产品、不同的开发语言等条件的限制。

  • AMQP的实现
    RabbitMQ、OpenAMQ、Apache Qpid、Redhat、Enterprise MRG、AMQP Infrastructure、ØMQ、Zyre等。

4 协议模型

image.png


5 AMQP核心概念

  • Server,又称Broker
    接受客户端的连接,实现AMQP实体服务
  • Connection 连接
    应用程序与Broker的网络连接
  • Channel,网络信道
    几乎所有操作都在Channel中进行,Channel是进行消息读写的通道。客户端可建立多个Channel,每个Channel代表一个会话任务
  • Message:消息

服务器和应用程序之间传送的数据,由Properties和Body组成。

  • Properties 可修饰消息, 比如消息的优先级、延迟等高级特性
  • Body 消息体内容
  • Virtual host:虚拟地址
    用于逻辑隔离,最上层的消息路由,类似命名空间。一个Virtual Host里可以有若干Exchange和Queue,同一Virtual Host里不能有相同名称的Exchange或Queue
  • Exchange:交换机
    接收消息,根据路由键转发消息到绑定的队列
  • Binding
    Exchange和Queue之间的虚拟连接,binding中可以包含routing key
  • Routing key
    一个路由规则,虚拟机可用它来确定如何路由一个特定消息
  • Queue,也称为Message Queue,消息队列
    保存消息并将它们转发给消费者

6 RabbitMQ工作架构模型

image.png

image.png

image.png

7 特性

1、可靠性

2、灵活的路由

3、消息集群

4、高可用

5、多种协议

6、多语言客户端

7、管理界面

8、插件机制

8 基本使用

8.1 常用命令

  • 启动服务
rabbitmq-server start &
• 1
  • 停止服务
rabbitmqctl stop_ app
• 1
  • 管理插件
rabbitmq-plugins enable rabbitmq_ management
• 1

8.2 重启操作

image.png

image.png

image.png

9 quickstart - 消息的生产与消费

9.1 基本构建缺一不可

  • ConnectionFactory:获取连接工厂
  • Connection:一个连接
  • Channel:数据通信信道,可发送和接收消息
  • Queue:具体的消息存储队列
  • Producer & Consumer生产和消费者

9.2 实操演示

  • Pro

image.png


  • Con

1.png

由于是Con端才创建有对列,所以必须先启动Con端,再启动Pro端!

分别启动运行


相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
14天前
|
消息中间件 存储 canal
阿里面试:canal+MQ,会有乱序的问题吗?
本文详细探讨了在阿里面试中常见的问题——“canal+MQ,会有乱序的问题吗?”以及如何保证RocketMQ消息有序。文章首先介绍了消息有序的基本概念,包括全局有序和局部有序,并分析了RocketMQ中实现消息有序的方法。接着,针对canal+MQ的场景,讨论了如何通过配置`canal.mq.partitionsNum`和`canal.mq.partitionHash`来保证数据同步的有序性。最后,提供了多个与MQ相关的面试题及解决方案,帮助读者更好地准备面试,提升技术水平。
阿里面试:canal+MQ,会有乱序的问题吗?
|
6天前
|
Android开发
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
|
6天前
|
消息中间件 存储 Java
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
|
6天前
|
XML 前端开发 Android开发
Android面试高频知识点(3) 详解Android View的绘制流程
Android面试高频知识点(3) 详解Android View的绘制流程
Android面试高频知识点(3) 详解Android View的绘制流程
|
8天前
|
消息中间件 Android开发 索引
Android面试高频知识点(4) 详解Activity的启动流程
Android面试高频知识点(4) 详解Activity的启动流程
16 3
|
9天前
|
XML 前端开发 Android开发
Android面试高频知识点(3) 详解Android View的绘制流程
Android面试高频知识点(3) 详解Android View的绘制流程
15 2
|
9天前
|
消息中间件 存储 Java
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
30 1
|
9天前
|
Android开发
Android面试高频知识点(1) 图解 Android 事件分发机制
Android面试高频知识点(1) 图解 Android 事件分发机制
23 1
|
14天前
|
XML 前端开发 Android开发
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
|
2月前
|
Web App开发 前端开发 Linux
「offer来了」浅谈前端面试中开发环境常考知识点
该文章归纳了前端开发环境中常见的面试知识点,特别是围绕Git的使用进行了详细介绍,包括Git的基本概念、常用命令以及在团队协作中的最佳实践,同时还涉及了Chrome调试工具和Linux命令行的基础操作。
「offer来了」浅谈前端面试中开发环境常考知识点

热门文章

最新文章