RabbitMq(尚硅谷)

RabbitMq

1.RabbitMq异步调用

2.work模型

3.Fanout交换机(广播模式)

4.Diret交换机(直连)

5.Topic交换机(主题交换机,通过路由匹配)

6.Headers交换机(头交换机)

6.生产者重连(Mq挂了,重新连接)

7.生产者确认(给生产者返回成功还是失败,成功返回ACK,失败返回NACK,三种方式,一般选择异步)

8.mq的可靠性-数据持久化(交换机,队列,消息持久化,持久化和临时消息队列,磁盘,内存)

9.Lazy Queue(惰性队列,保留条数2048,.lazy()开启Lazy Queue,正常消息是保存在内存,这个是保存在磁盘)

10.消费者确认机制(三种返回,ack:成功,nack:失败,重新投递,reject:失败拒绝该消息,三种消息确认选择模式,不处理,手动处理,自动模式)

11.消费者失败机制(失败后会不断入队,会无限循环异常)

12.业务幂等性(f(x)=f(f(x)))

13.延迟消息.死信交换机

14.延迟消息.延迟消息插件(通过消息头设置过期时间)

15.延迟消息.取消超时订单(定义延迟消息时间间隔,加起来对于某一个时间如30分钟)

16.RabbitMq集群(提高整体工作性能)

17.镜像队列(默认队列只会在某一个服务器显示,其他集群内的服务器不显示)

18.RabbitMq的高可用负载均衡

19.FederationExchange(联邦交换机,需要下载对应插件,让两个不同地方的服务器保存数据一致)

20.Shovel

Shovel是 RabbitMQ 提供的一个插件,用于在 不同的 RabbitMQ 节点之间(或集群之间)进行消息迁移、复制或转发。与联邦交换机(Federation)类似,它也是跨节点通信的一种方式,但 Shovel 的工作方式和使用场景有所不同。

RabbitMQ 概述

RabbitMQ 是一个实现了高级消息队列协议(AMQP)的消息代理软件,它支持多种消息传递模式,并且可以用于构建可靠、可扩展的分布式系统。


消息队列的作用

  • 解耦:生产者和消费者不需要直接交互。
  • 缓冲:平滑瞬时高峰流量,保护后端服务。
  • 异步通信:提高系统的响应速度。
  • 可靠性:确保消息被正确处理,即使在出现故障的情况下。

生产消费模型

  • 生产者(Producer):创建消息并发送到交换机(Exchange)。
  • 消费者(Consumer):从队列中接收并处理消息。
  • 消息队列(Queue):存储消息直到被消费者处理。

交换机模型

  • Direct Exchange:根据路由键精确匹配。
  • Fanout Exchange:广播消息给所有绑定的队列。
  • Topic Exchange:基于模式匹配的路由键进行分发。
  • Headers Exchange:通过消息头属性匹配。

死信队列(Dead Letter Queue, DLQ)

  • 当消息无法正常消费时(如达到最大重试次数),会被转发到死信队列。
  • 需要在队列或消息上设置 x-dead-letter-exchange 参数指定死信交换机。

延迟队列

  • 使用 TTL(Time To Live)与死信交换机结合实现延迟消息的功能。
  • 消息过期后会自动进入配置好的死信队列,从而实现延迟效果。

消息持久化

  • 设置消息为持久化(deliveryMode=2),即使服务器重启也能保留消息。
  • 同样需要将队列和交换机也设置为持久化。

Java 操作

使用 AMQP 协议与 RabbitMQ 进行交互,可以通过 Java 客户端库(如 amqp-client 或 Spring AMQP)来发送和接收消息。

复制代码

java

深色版本

复制代码
// 发送消息示例
ConnectionFactory factory = new ConnectionFactory();
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();

channel.queueDeclare("hello", true, false, false, null);
String message = "Hello World!";
channel.basicPublish("", "hello", MessageProperties.PERSISTENT_TEXT_PLAIN,
    message.getBytes(StandardCharsets.UTF_8));

集群搭建

  1. 安装 RabbitMQ 节点:在多台机器上安装 RabbitMQ。

  2. 配置 Erlang Cookie:确保所有节点使用相同的 Erlang cookie 文件以允许节点间通信。

  3. 加入集群

    复制代码

    bash

    深色版本

    复制代码
    rabbitmqctl stop_app
    rabbitmqctl reset
    rabbitmqctl join_cluster rabbit@hostname_of_existing_node
    rabbitmqctl start_app
  4. 镜像队列策略:为了高可用性,可以配置镜像队列策略使队列数据在多个节点之间复制。

相关推荐
ZHOU_WUYI3 小时前
一个简单的分布式追踪系统
分布式
码不停蹄的玄黓7 小时前
MySQL分布式ID冲突详解:场景、原因与解决方案
数据库·分布式·mysql·id冲突
王小王-1238 小时前
基于Hadoop的公共自行车数据分布式存储和计算平台的设计与实现
大数据·hive·hadoop·分布式·hadoop公共自行车·共享单车大数据分析·hadoop共享单车
要开心吖ZSH9 小时前
《Spring 中上下文传递的那些事儿》Part 4:分布式链路追踪 —— Sleuth + Zipkin 实践
java·分布式·spring
csdn_aspnet10 小时前
在 Windows 机器上安装和配置 RabbitMQ
windows·rabbitmq
幼稚园的山代王10 小时前
RabbitMQ 4.1.1初体验
分布式·rabbitmq·ruby
csdn_aspnet10 小时前
Windows Server 上的 RabbitMQ 安装和配置
windows·rabbitmq
百锦再10 小时前
RabbitMQ用法的6种核心模式全面解析
分布式·rabbitmq·路由·消息·通道·交换机·代理
deriva10 小时前
.netcore+ef+redis+rabbitmq+dotcap先同步后异步再同步的方法,亲测有效
redis·rabbitmq·.netcore
一路向北North10 小时前
RabbitMQ简单消息监听和确认
分布式·rabbitmq·ruby