首页 RabbitMQ
文章
取消

RabbitMQ

1.初识RabbitMq

image-20240310121737868

image-20240310122230649

同步调用存在的问题

image-20240310122123644

异步调用方案

优势:

image-20240310122430301

image-20240310122650968

image-20240310122853180

image-20240310122832067

image-20240310122947044

2.什么是MQ

image-20240310123714239

国内一般选用1、3、4

一般公司选用RabbitMQ,性能够用,可用性高,消息可靠性高都是他的亮点

大公司选用kafka,单机吞吐量高,

image-20240310133434705

image-20240310133612152

3.RabbitMQ快速入门

image-20240310133829219

image-20240310133850035

image-20240310134703966

4.SpringAMQP

image-20240310134802151

1.简单队列案例:

image-20240310135202014

image-20240310135224476

image-20240310135432272

image-20240310135928416

image-20240310145140128

2.WorkQueue 工作队列

image-20240310145940398

image-20240310152210123

3.发布订阅

image-20240310152941028

1.FanoutExchange

image-20240310153046177

image-20240310153250958

image-20240310153338229

image-20240310153424330

image-20240310153935112

image-20240310153957835

image-20240310154106330

2.DirectExchange

image-20240310154400748

案例:

image-20240310154548094

步骤一:image-20240310154626260

image-20240310155157200

image-20240310155249464

3.TopicExchange

image-20240310155410999

image-20240310164634769

案例:

image-20240310165138822

image-20240310165244447

image-20240310165805986

image-20240310165823914

image-20240310170118997

image-20240310170303454

5.RabbitMQ部署指南

1.单机部署

我们在Centos7虚拟机中使用Docker来安装。

1.1.下载镜像

方式一:在线拉取

1
docker pull rabbitmq:3-management

方式二:从本地加载

在课前资料已经提供了镜像包:

image-20210423191210349

上传到虚拟机中后,使用命令加载镜像即可:

1
docker load -i mq.tar

1.2.安装MQ

执行下面的命令来运行MQ容器:

1
2
3
4
5
6
7
8
9
docker run \
 -e RABBITMQ_DEFAULT_USER=itcast \
 -e RABBITMQ_DEFAULT_PASS=123321 \
 --name mq \
 --hostname mq1 \
 -p 15672:15672 \
 -p 5672:5672 \
 -d \
 rabbitmq:3-management

2.集群部署

接下来,我们看看如何安装RabbitMQ的集群。

2.1.集群分类

在RabbitMQ的官方文档中,讲述了两种集群的配置方式:

  • 普通模式:普通模式集群不进行数据同步,每个MQ都有自己的队列、数据信息(其它元数据信息如交换机等会同步)。例如我们有2个MQ:mq1,和mq2,如果你的消息在mq1,而你连接到了mq2,那么mq2会去mq1拉取消息,然后返回给你。如果mq1宕机,消息就会丢失。
  • 镜像模式:与普通模式不同,队列会在各个mq的镜像节点之间同步,因此你连接到任何一个镜像节点,均可获取到消息。而且如果一个节点宕机,并不会导致数据丢失。不过,这种方式增加了数据同步的带宽消耗。

我们先来看普通模式集群。

2.2.设置网络

首先,我们需要让3台MQ互相知道对方的存在。

分别在3台机器中,设置 /etc/hosts文件,添加如下内容:

1
2
3
192.168.150.101 mq1
192.168.150.102 mq2
192.168.150.103 mq3

并在每台机器上测试,是否可以ping通对方:

本文由作者按照 CC BY 4.0 进行授权
热门标签