初识RabbitMQ系列之一:简单介绍

一:RabbitMQ是什么?

众所周知,MQ是Message  Queue(消息队列)的意思,RabbitMQ就是众多MQ框架其中的一款,开源实现了AMQP协议(官网:http://www.amqp.org/),也就是说RabbitMQ是一个开源的消息队列框架。

他用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面都非常的优秀。是当前最主流的消息中间件之一。

RabbitMQ的官网:http://www.rabbitmq.com

二:RabbitMQ优势&劣势?

优势:

  1:安装部署简单,上手门槛低,符合AMQP标准;

  2:集群易扩展,可以轻松的增减集群节点,通过增加节点可以实现成倍的性能提升;

  3:有强大的WEB管理页面;

  4:支持消息持久化、支持消息确认机制、灵活的任务分发机制等;

  5:可靠性高,不会丢失消息;

劣势:

  1:性能相对 kafka、zero相比要差很多;

三:何时选择RabbitMQ使用?

  如果你希望使用一个可靠性高、功能强大、易于管理的消息队列系统那么就选择RabbitMQ;

  如果你想用一个性能高,但偶尔丢点数据不是很在乎可以使用kafka或者zeroMQ。

四:RabbitMQ 的系统架构

RabbitMQ整个执行过程如下:

    (1)生产者客户端连接到消息队列服务器,创建一个channel。

    (2)生产者客户端定义一个转发器exchange,并设置相关属性。

    (3)生产者客户端定义一个路由标识,并发送消息到exchange。

    (3)消费者客户端定义一个queue,并设置相关属性。

    (4)消费者客户端使用routing key,在exchange和queue之间建立好绑定关系。

    (5)绑好关系后,发送端只要发送符合路由规则的消息,都会被exchange分发到对应的queue上,客户端就可以直接在queue上获取到消息了。

    如上图所示:AMQP 里主要要说两个组件:Exchange 和 Queue

    绿色的 X 就是 Exchange ,红色的是 Queue ,这两者都在 Server 端,又称作 Broker ,

    这部分是 RabbitMQ 实现的,而蓝色的则是客户端,通常有 Producer 和 Consumer 两种类型。

五:RabbitMQ的核心概念

    生产者:数据的发送方,把消息发送到交换机。

    消费者:数据的接收方,从队列接收消息

    Exchange:消息交换机,会根据设置好的规则把消息分发到一个或多个队列上。

    Queue:消息队列载体,所有消息最终都会被投入到一个或多个队列。

    Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。

    Routing Key:路由关键字,exchange根据这个关键字进行消息投递,发送消息和绑定的时候都用得到。

    vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。

    channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。

这些概念非常重要,都是核心概念,一定要弄清楚。

时间: 2024-12-07 03:32:26

初识RabbitMQ系列之一:简单介绍的相关文章

[STL系列]开篇简单介绍

开篇: 为了应付上机考,现在需要总结下关于STL的基础知识.由于以前各种代码都喜欢从头搭起,像这种现成的牛逼的STL就没怎么看,真是作死.现在来突击啦. 开始之前,简单看一段代码,功能很简单,就是要实现对一组数字的排序,以窥STL的一斑. 1 #include "iostream" 2 #include <algorithm> 3 #include <vector> 4 using namespace std; 5 6 int main() 7 { 8 vect

初识RabbitMQ系列之一HelloWorld

Server端代码: 1 package com.helloworld; 2 3 import java.io.IOException; 4 5 import com.rabbitmq.client.Channel; 6 import com.rabbitmq.client.Connection; 7 import com.rabbitmq.client.ConnectionFactory; 8 9 public class Send { 10 /** 发送目的地队列名称 */ 11 priva

Maven实战之初识MavenMaven的简单介绍

Maven实战之初识MavenMaven的简单介绍 作用:Maven主要用于项目的构建,管理项目的依赖以及项目的信息(自动化构建.编译.单元测试.生成文档.打包.部署) 优势:相对于Ant.Make等,Maven抽象构建过程,提供构建任务的实现,自动化构建,有效地提高了开发效率,使开发人员可以集中精力在主要的开发任务上.而且Maven是跨平台工具,意味着在主流操作系统中,Maven都提供了对应的技术支持 使用注意:需要在JDK1.4及以上版本使用 Maven的安装下载地址:Maven下载地址,选

Https系列之一:https的简单介绍及SSL证书的生成

Https系列会在下面几篇文章中分别作介绍: 一:https的简单介绍及SSL证书的生成二:https的SSL证书在服务器端的部署,基于tomcat,spring boot三:让服务器同时支持http.https,基于spring boot四:https的SSL证书在Android端基于okhttp,Retrofit的使用 所有文章会优先在:微信公众号"颜家大少"中发布转载请标明出处 一:本文的主要内容介绍 https的介绍SSL证书的介绍自签名SSL证书介绍及生成方法CA证书介绍及申

rabbitmq简单介绍

引言 你是否遇到过两个(多个)系统间需要通过定时任务来同步某些数据?你是否在为异构系统的不同进程间相互调用.通讯的问题而苦恼.挣扎?如果是,那么恭喜你,消息服务让你可以很轻松地解决这些问题.消息服务擅长于解决多系统.异构系统间的数据交换(消息通知/通讯)问题,你也可以把它用于系统间服务的相互调用(RPC).本文将要介绍的RabbitMQ就是当前最主流的消息中间件之一. RabbitMQ简介 AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层

RabbitMQ简单介绍及安装使用

一.RabbitMQ简单介绍 二.安装配置1.安装环境 CentOS7 server1 190.168.3.250安装包依赖[[email protected] ~]# yum -y install gcc gcc-c++ m4 ncurses-devel openssl-devel2.安装RabbitMQ 按顺序安装:3.配置[[email protected] ~]# vim /usr/lib/rabbitmq/lib/rabbitmq_server-3.6.14/ebin/rabbit.a

Rabbitmq 简单介绍,安装和go客户端使用

Rabbitmq 简单介绍,安装和go客户端使用 1,消息队列介绍 1.1 什么是消息队列? 消息队列(英语:Message queue)是一种进程间通信或同一进程的不同线程间的通信方式,软件的贮列用来处理一系列的输入,通常是来自用户.消息队列提供了异步的通信协议,每一个贮列中的纪录包含详细说明的数据,包含发生的时间,输入设备的种类,以及特定的输入参数,也就是说:消息的发送者和接收者不需要同时与消息队列互交.消息会保存在队列中,直到接收者取回它.消息队列,一般我们会简称他为MQ(Message

rabbitmq的简单介绍

python操作rabbitmq的模块叫做pika 1个生产者对应1个消费者 如果生产者发送一条消息,那么消费者也只能接受到1条消息如果生产者发送两条消息,那么消费者就可以接受到2条消息 1个生产者对应2个消费者如果生产者发送1条消息,那么只有1个消费者能接受到消息如果生产者发送2条消息,那么每个消费者都接受到1条消息 如果生产者先启动了,生产者的代码已经执行完成,程序退出,这个时候消费者才启动,消费者也能接受到消息 work queue如果一个生产者对应多个消费者,那么生产者会依次把消息轮训到

JBoss 系列九十六:JBoss MSC - 简单介绍及一个简单示例

什么是 JBoss MSC JBoss MSC 即 JBoss Modular Service Container,是第三代 JBoss 产品 JBoss 7和WildFfly的内核,JBoss MSC 替换了之前的 JMX Kernel 和 MicroContainer,它主要特定可以总结如下三点: 高并发容器(A highly concurrent state machine) 无多相位,设计简单(No multiple phases, much simpler) 不依赖 JMX 和 Jav