Spring Boot 中的 RabbitMQ 消息发送配置

这篇具有很好参考价值的文章主要介绍了Spring Boot 中的 RabbitMQ 消息发送配置。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Spring Boot 中的 RabbitMQ 消息发送配置

1. 什么是 RabbitMQ

RabbitMQ 是一个开源的消息代理系统,它实现了 AMQP(高级消息队列协议)标准,并支持多种消息传输协议。它具有高可用性、可扩展性和可靠性,广泛应用于分布式系统、微服务架构、异步任务处理、日志收集等场景。

RabbitMQ 的核心概念包括:

  • Producer:消息生产者,负责将消息发送到 RabbitMQ 服务器。
  • Exchange:消息交换机,负责接收 Producer 发送的消息,并将其路由到一个或多个 Queue。
  • Queue:消息队列,负责存储消息。
  • Consumer:消息消费者,从 Queue 中获取消息并进行处理。
    rabbitmq 发送消息,Java 教程,spring boot,后端,java

2. Spring Boot 中的 RabbitMQ 自动配置

Spring Boot 提供了对 RabbitMQ 的自动配置支持,通过在配置文件中添加以下配置,即可快速集成 RabbitMQ:

spring.rabbitmq.host=your-host
spring.rabbitmq.port=your-port
spring.rabbitmq.username=your-username
spring.rabbitmq.password=your-password

Spring Boot 的 RabbitMQ 自动配置会根据上述配置创建一个 ConnectionFactory 对象,并使用 RabbitTemplate 封装一些常用的 RabbitMQ 操作,例如发送消息、接收消息等。

在使用 Spring Boot 的 RabbitMQ 自动配置时,我们需要添加 RabbitMQ 的依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

3. RabbitMQ 消息发送配置

3.1. 发送消息

在 Spring Boot 中,我们可以使用 RabbitTemplate 来发送消息。RabbitTemplate 提供了一个简单的 API,用于发送消息到 RabbitMQ 服务器。以下是一个发送消息的示例代码:

@Autowired
private RabbitTemplate rabbitTemplate;

public void sendMessage(String message) {
    rabbitTemplate.convertAndSend("exchangeName", "routingKey", message);
}

在这个示例中,我们使用 RabbitTemplateconvertAndSend 方法来发送消息。其中,exchangeName 表示消息交换机的名称,routingKey 表示消息路由键,message 表示要发送的消息内容。

3.2. 消息确认

RabbitMQ 提供了消息确认机制,用于确保消息被正确地发送到 RabbitMQ 服务器。在 Spring Boot 中,我们可以通过配置 RabbitTemplate 来开启消息确认机制。以下是一个开启消息确认机制的示例代码:

@Bean
public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
    RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
    rabbitTemplate.setConfirmCallback((correlationData, ack, cause) -> {
        if (!ack) {
            log.error("Message send failed: {}", cause);
        }
    });
    return rabbitTemplate;
}

在这个示例中,我们通过设置 RabbitTemplateConfirmCallback 来开启消息确认机制。当消息发送成功时,ConfirmCallbackack 参数为 true,否则为 falsecause 参数表示发送失败的原因。

3.3. 消息序列化

在 Spring Boot 中,我们可以使用 MessageConverter 来对消息进行序列化和反序列化。默认情况下,Spring Boot 使用 SimpleMessageConverter 对消息进行序列化和反序列化。如果我们需要使用自定义的序列化方式,可以实现 MessageConverter 接口,并将其配置到 RabbitTemplate 中。以下是一个自定义的消息序列化器的示例代码:

public class MyMessageConverter implements MessageConverter {
    @Override
    public Message toMessage(Object object, MessageProperties messageProperties) throws MessageConversionException {
        // 将对象转换为字节数组
        byte[] body = new byte[0];
        try {
            ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
            ObjectOutputStream objectOutputStream = new ObjectOutputStream(byteArrayOutputStream);
            objectOutputStream.writeObject(object);
            objectOutputStream.flush();
            body = byteArrayOutputStream.toByteArray();
        } catch (IOException e) {
            e.printStackTrace();
        }
        // 创建 Message 对象
        Message message = new Message(body, messageProperties);
        return message;
    }

    @Override
    public Object fromMessage(Message message) throws MessageConversionException {
        // 将字节数组转换为对象
        Object object = null;
        try {
            ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(message.getBody());
            ObjectInputStream objectInputStream = new ObjectInputStream(byteArrayInputStream);
            object = objectInputStream.readObject();
        } catch (IOException | ClassNotFoundException e) {
            e.printStackTrace();
        }
        return object;
    }
}

@Bean
public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
    RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
    rabbitTemplate.setMessageConverter(new MyMessageConverter());
    return rabbitTemplate;
}

在这个示例中,我们实现了一个自定义的消息序列化器 MyMessageConverter,并将其配置到 RabbitTemplate 中。在 MyMessageConverter 中,我们通过实现 toMessagefromMessage 方法来对消息进行序列化和反序列化。

4. 总结

Spring Boot 提供了对 RabbitMQ 的自动配置支持,可以帮助我们快速集成 RabbitMQ,并提供一些默认的配置,例如连接池、消息确认机制、消息序列化等。在使用 Spring Boot 的 RabbitMQ 自动配置时,我们可以使用 RabbitTemplate 来发送消息,也可以通过配置 RabbitTemplate 来开启消息确认机制和使用自定义的消息序列化器。

如果您正在开发一个基于 Spring Boot 的应用程序,并需要使用 RabbitMQ 来实现消息发送功能,那么 Spring Boot 中的 RabbitMQ 自动配置是您的一个不错的选择。文章来源地址https://www.toymoban.com/news/detail-729602.html

到了这里,关于Spring Boot 中的 RabbitMQ 消息发送配置的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring Boot 整合 RabbitMQ 实现延迟消息

    消息队列(Message Queuing,简写为 MQ)最初是为了解决金融行业的特定业务需求而产生的。慢慢的,MQ 被应用到了更多的领域,然而商业 MQ 高昂的价格让很多初创公司望而却步,于是 AMQP(Advanced Message Queuing Protocol,高级消息队列协议)应运而生。 随着 AMQP 草案的发布,两个月

    2024年04月08日
    浏览(34)
  • RabbitMQ 消息队列(Spring boot AMQP)

    几种常见MQ的对比: RabbitMQ ActiveMQ RocketMQ Kafka 公司/社区 Rabbit Apache 阿里 Apache 开发语言 Erlang Java Java ScalaJava 协议支持 AMQP,XMPP,SMTP,STOMP OpenWire,STOMP,REST,XMPP,AMQP 自定义协议 自定义协议 可用性 高 一般 高 高 单机吞吐量 一般 差 高 非常高 消息延迟 微秒级 毫秒级 毫秒级 毫

    2024年02月13日
    浏览(30)
  • Spring Cloud Stream 4.0.4 rabbitmq 发送消息多function

    注意当多个消费者时,需要添加配置项:spring.cloud.function.definition 启动日志 交换机名称对应: spring.cloud.stream.bindings.demo-in-0.destination配置项的值 队列名称是交换机名称+分组名 http://localhost:8080/sendMsg?delay=10000name=zhangsan 问题总结 问题一 解决办法: 查看配置是否正确: spring

    2024年02月19日
    浏览(33)
  • RabbitMQ可靠性消息发送(java实现)

    本博客属于 《RabbitMQ基础组件封装—整体结构》的子博客 step1:消息落库,业务数据存库的同时,也要将消息记录存入数据库,二者要保证原子性; step2:Producer发送消息到MQ Broker; step3:Producer收到 broker 返回的确认消息; step4:更改消息记录库的状态(定义三种状态:0待确

    2024年02月04日
    浏览(59)
  • Spring Boot 项目应用消息服务器RabbitMQ(简单介绍)

    本章讲述的是在用户下单环节,消息服务器RabbitMQ 的应用 在写一个电商项目的小demo,在电商项目中,消息服务器的应用: 1、订单状态通知:当用户下单、支付成功、订单发货、订单完成等关键节点时,可以通过消息服务器向用户发送相应的订单状态通知。 2、消息推送:通

    2024年02月13日
    浏览(59)
  • java操作rabbitmq实现简单的消息发送(socket编程的升级)

    准备: 1.下载rabbitmq并搭建环境(和python那篇一样:http://www.cnblogs.com/g177w/p/8176797.html) 2.下载支持的jar包(http://repo1.maven.org/maven2/com/rabbitmq/amqp-client) 生产者方(Productor.java): View Code 消费者方(Consummer.java):

    2023年04月08日
    浏览(33)
  • Spring Boot 中的 RabbitMQ 是什么,如何使用

    RabbitMQ 是一个开源的消息队列系统,它通过 AMQP(高级消息队列协议)来实现消息的传递。Spring Boot 是目前非常流行的 Java 开发框架,它提供了很多便利性的功能,其中就包括对 RabbitMQ 的支持。 在本文中,我们将介绍 RabbitMQ 的基本概念,以及如何在 Spring Boot 中使用 RabbitMQ。

    2024年02月12日
    浏览(39)
  • Spring Boot + RabbitMQ 配置参数解释

    spring.rabbitmq.host: 服务Host spring.rabbitmq.port: 服务端口 spring.rabbitmq.username: 登陆用户名 spring.rabbitmq.password: 登陆密码 spring.rabbitmq.virtual-host: 连接到rabbitMQ的vhost spring.rabbitmq.addresses: 指定client连接到的server的地址,多个以逗号分隔(优先取addresses,然后再取host) spring.rabbitmq.requested

    2024年01月24日
    浏览(37)
  • spring cloud 搭建消息中间件 RabbitMQ 环境、Mac/Windows下载安装RabbitMQ、配置RabbitMQ环境变量

    spring boot、spring cloud工程:Mac/Windows下载安装Erlang、RabbitMQ,并配置环境变量。 这里学习如何安装 RabbitMQ,因为远程配置中心的动态更新需要结合 RabbitMQ 来使用。 这里给出自己下载和使用的百度网盘链接:Erlang 版本为25.3.2、RabbitMQ版本为3.12.1 : 链接:百度网盘链接 提取码:

    2024年02月15日
    浏览(59)
  • Spring Boot中RabbitMQ自动配置的介绍、原理和使用

    RabbitMQ是一种高性能的消息队列系统,它支持多种消息协议和丰富的功能,如消息路由、消息确认、消息重试、死信队列等。在Spring Boot中,我们可以通过自动配置的方式来使用RabbitMQ。本文将介绍Spring Boot中RabbitMQ自动配置的介绍、原理和使用方法。 在Spring Boot中,我们可以通

    2024年02月11日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包