Spring Boot整合RabbitMQ


本文是作者原創,版權歸作者所有.若要轉載,請注明出處.

本文RabbitMQ版本為rabbitmq-server-3.7.17,erlang為erlang-22.0.7.請各位去官網查看版本匹配和下載,也可以留言,我發安裝包

 

在Spring項目中,可以使用Spring-Rabbit去操作RabbitMQ https://github.com/spring-projects/spring-amqp

尤其是在spring boot項目中只需要引入對應的amqp啟動器依賴即可,方便的使用RabbitTemplate發送消息,使用注解接收消息。

 

搭建生產者工程

1. 創建工程

創建生產者工程springboot-rabbitmq-producer

2. 添加依賴

   <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.4.RELEASE</version>
    </parent>

    <dependencies>
        <!-- 使用springmvc來進行測試 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--amqp的起步依賴-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>
        <!--單元測試類-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
    </dependencies>

3. 啟動類

@SpringBootApplication
public class ProducerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ProducerApplication.class, args);
    }

}

4. 配置RabbitMQ

application.yml,內容如下:

#tomcat端口
server:
  port: 8888
#Rabbitmq的配置
spring:
  rabbitmq:
    host: 192.168.75.163
    port: 5672
    virtual-host: /hello
    username: test01
    password: test01

創建RabbitMQ隊列與交換機綁定的配置類RabbitMQConfig

/**
 * RabbitMQ配置類
 */
@Configuration
public class RabbitMQConfig {
    //交換機名稱
    public static final String ITEM_TOPIC_EXCHANGE = "item_topic_exchange";
    //隊列名稱
    public static final String ITEM_QUEUE = "item_queue";

    //聲明交換機
    @Bean("itemTopicExchange")
    public Exchange topicExchange(){
        return ExchangeBuilder.topicExchange(ITEM_TOPIC_EXCHANGE).durable(true).build();
    }

    //聲明隊列
    @Bean("itemQueue")
    public Queue itemQueue(){
        return QueueBuilder.durable(ITEM_QUEUE).build();
    }

    //綁定隊列和交換機
    @Bean
    public Binding itemQueueExchange(@Qualifier("itemQueue") Queue queue,
                                     @Qualifier("itemTopicExchange") Exchange exchange){
        return BindingBuilder.bind(queue).to(exchange).with("item.#").noargs();
    }

}

5 消息發送Controller

@RestController
public class SendMsgController {

//注入RabbitMQ的模板
@Autowired
private RabbitTemplate rabbitTemplate;

/**
* 測試
*/
@GetMapping("/sendmsg")
public String sendMsg(@RequestParam String msg, @RequestParam String key){
/**
* 發送消息
* 參數一:交換機名稱
* 參數二:路由key: item.springboot-rabbitmq,符合路由item.#規則即可
* 參數三:發送的消息
*/
rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_TOPIC_EXCHANGE ,key ,msg);
//返回消息
return "發送消息成功!";
}
}

6發送消息

http://localhost:8888/sendmsg?msg=springboot-rabbitmq-producer&key=item.springboot-rabbitmq

查看結果

 

 

 

 

 

 

 

 

搭建消費者工程

1. 創建工程

創建消費者工程springboot-rabbitmq-consumer

2. 添加依賴

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.4.RELEASE</version>
    </parent>

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

3. 啟動類

@SpringBootApplication
public class ConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
}

4. 配置RabbitMQ

application.yml,內容如下:

#端口,注意端口不要沖突
server:
  port: 9999
#Rabbitmq的配置
spring:
  rabbitmq:
    host: 192.168.75.163
    port: 5672
    virtual-host: /hello
    username: test01
    password: test01

5. 消息監聽處理類MyListener

@Component
public class MyListener {

@RabbitListener(queues = "item_queue")
public void msg(String msg){
System.out.println("消費者消費消息了:"+msg);
//TODO 這里可以做異步的工作
}
}

6. 測試(消息內容為test)

http://localhost:8888/sendmsg?msg=test&key=item.springboot-rabbitmq

查看結果

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM