Spring Boot整合RabbitMQ——生产者发送确认

文章目录

        • 1. 生产者发送确认简介
        • 2. 事务消息机制
          • 2.1 原理
          • 2.2 快速搭建项目
        • 3. 发送方Confirm Callback机制
          • 3.1 原理
          • 3.2 快速项目搭建
        • 4. 发送方Return Callback机制
          • 4.1 原理
          • 4.2 快速项目搭建
        • 5. Return Callback与Confirm Callback的区别

1. 生产者发送确认简介

生产者发送消息真的成功到达rabbitmq broker服务节点了吗?默认情况下,生产者发送消息的方法没有任何返回信息,也就是说如果消息在发送broker节点的过程中由于出现网络问题而丢失了,生产者是不知道这件事情的。显而易见这是个问题,该怎么解决呢?幸运的是,rabbitmq给我们提供了两种方法来解决这个问题:

  • 事务消息机制
  • 发送方确认机制
2. 事务消息机制
2.1 原理

RabbitMQ中与事务消息机制有关的方法有三个:txSelect()、txCommit()、txRollback()。 txSelect用于将当前channel设置成transaction模式,txCommit用于提交事务,txRollback用于回滚事务。通过txSelect开启事务之后,我们便可以发送消息给broker节点服务了,如果txCommit提交成功,则消息一定到达了broker节点,否则通过txRollback回滚事务。

2.2 快速搭建项目

(1) pom文件添加amqp依赖


<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0modelVersion>
    <parent>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-parentartifactId>
        <version>2.4.2version>
        <relativePath/>
    parent>

    <groupId>com.examplegroupId>
    <artifactId>tx-rabbitmq-demoartifactId>
    <version>0.0.1-SNAPSHOTversion>
    <name>tx-rabbitmq-demoname>
    <description>Demo project for Spring Bootdescription>

    <properties>
        <java.version>1.8java.version>
    properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-amqpartifactId>
        dependency>

        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-webartifactId>
        dependency>

        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-testartifactId>
            <scope>testscope>
        dependency>
    dependencies>
project>

你可能感兴趣的:(Spring,Boot,rabbitmq,java)