zoukankan      html  css  js  c++  java
  • springboot 整合rabbitMQ 实现生产者与消费者实例【入门级】

    一、什么是Exchange

      RabbitMQ 是 AMQP(高级消息队列协议)的标准实现:

     从 AMQP 协议可以看出,Queue、Exchange 和 Binding 构成了 AMQP 协议的核心

    • Producer:消息生产者,即投递消息的程序。

    • Broker:消息队列服务器实体。

      • Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

      • Binding:绑定,它的作用就是把 Exchange 和 Queue 按照路由规则绑定起来。

      • Queue:消息队列载体,每个消息都会被投入到一个或多个队列。

    • Consumer:消息消费者,即接受消息的程序。

    二、Exchange的类型

    RabbitMQ常用的Exchange Type有fanout、direct、topic、headers这四种,本文主要通过direct方式,实现生产者与消费者实例

    三、具体操作步骤

    1. 创建生产者 新建springboot web项目,file->new->project

    •  在pom.xml文件添加引用
        <!-- 添加springboot对amqp的支持 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-amqp</artifactId>
            </dependency>
            <!-- SLf4j 日志记录-->
            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
                <optional>true</optional>
                <version>1.18.12</version>
            </dependency>
    
    • 在application.properties文件中添加连接MQ配置,注意端口是5672,不是15672,15672是web浏览端口
    # 应用名称
    spring.application.name=springboot-rabbitmq-receive
    
    spring.rabbitmq.host=127.0.0.1
    spring.rabbitmq.port=5672
    spring.rabbitmq.username=guest
    spring.rabbitmq.password=guest
    
    • 创建RabbitMQ配置类,注意添加的注解是Configuration 
    package com.howdy.common.config;
    
    import org.springframework.amqp.core.Queue;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    
    @Configuration //注意 这个地方不是 Configurable
    public class RabbitMQConf {
    
        @Bean
        public Queue helloQueue() {
            // 第一个参数是创建的queue的名字,第二个参数是是否支持持久化
            return new Queue("hello_queue_test", true);
        }
    }
    

      

    • 创建发送消息服务类
    package com.howdy.common.service;
    
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.amqp.core.AmqpTemplate;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    
    @Service
    @Slf4j
    public class HelloSender {
    
        @Autowired
        private AmqpTemplate template;
    
        public void Send() {
            String msg = "hello rabbitmq...";
            template.convertAndSend("hello_queue_test", msg);
            log.info("hello_queue_test队列发送消息:" + msg);
        }
    }
    
    • 创建测试方法类
    package com.howdy.common.controller;
    
    import com.howdy.common.service.HelloSender;
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    @RequestMapping("/test")
    public class TestRabbitMQ {
    
        @Autowired
        private HelloSender helloSender;
    
       @GetMapping("/testRabbit")
        public String  testRabbit(){
            helloSender.Send();
            return "消息发送成功";
        }
    
    }
    
    • 生产者 完整目录结构

      2、创建消费者项目,大部分与生产者相同,下面我只列出不同的地方

    • 创建消费端,消费方法
    package com.howdy.common.service;
    
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.amqp.rabbit.annotation.RabbitHandler;
    import org.springframework.amqp.rabbit.annotation.RabbitListener;
    import org.springframework.stereotype.Component;
    
    @Component
    @Slf4j
    public class HelloReceive {
    
        @RabbitHandler
        @RabbitListener(queues = "hello_queue_test") //监听队列名为hello的队列
        public void ProcessClient(String msg) {
            log.info("消费端接收到消息:"+msg);
        }
    }
    

      

    • 完整目录结构

    • 最后测试结果,如图:

      源码下载:https://download.csdn.net/download/haojuntu/14045792

  • 相关阅读:
    java学习笔记07-循环
    java学习笔记06-条件语句
    java学习笔记05-运算符
    java学习笔记04-基本数据类型
    java学习笔记03-基本语法
    java学习笔记02-Eclipse IDE配置
    java学习笔记01-环境配置
    Jmeter学习笔记03-元件作用域及执行顺序
    JMeter学习笔记02-基础介绍
    [luogu3369/bzoj3224]普通平衡树(splay模板、平衡树初探)
  • 原文地址:https://www.cnblogs.com/personblog/p/14251641.html
Copyright © 2011-2022 走看看