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. 镜像队列策略:为了高可用性,可以配置镜像队列策略使队列数据在多个节点之间复制。

相关推荐
predisw1 小时前
Kafka broker 写消息的过程
分布式·kafka
找不到、了3 小时前
深入学习RabbitMQ队列的知识
分布式·rabbitmq
showmethetime3 小时前
RabbitMQ实用技巧
分布式·rabbitmq·ruby
KwokGuardian4 小时前
Seata 分布式事务 AT 模式
分布式
不爱学英文的码字机器5 小时前
[Git] 分布式版本控制 & 远程仓库协作
分布式·git
火龙谷5 小时前
【hadoop】Davinci数据可视化工具的安装部署
大数据·hadoop·分布式
慧一居士11 小时前
ShardingSphere-JDBC 与 Sharding-JDBC 的对比与区别
分布式·系统架构
隰有游龙14 小时前
hadoop集群启动没有datanode解决
大数据·hadoop·分布式
UCoding14 小时前
我们来学zookeeper -- 集群搭建
分布式·zookeeper
小马哥编程15 小时前
【ISAQB大纲解读】Kafka消息总线被视为“自下而上设计”?
分布式·kafka·系统架构·linq