RabbitMQ整合Spring Boot,实现第一个Hello World

本文介绍了MQ(Message Queue)的基本概念及其在流量消峰、应用解耦和异步处理中的作用。通过实例展示了如何使用Spring Boot和RabbitMQ实现消息队列的发送与接收。首先,引入Spring Boot的AMQP依赖,然后配置RabbitMQ的连接信息。接着,创建生产者和消费者代码,生产者发送消息到指定队列,消费者监听并消费该队列中的消息。通过这个简单的HelloWorld案例,读者可以快速上手RabbitMQ。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、什么是MQ(message queue),是一个队列,先进先出。

2、为什么要MQ?

  • 流量消峰:
  • 应用解藕
  • 异步处理

3、启动

# 后台启动
rabbitmq-server -detached

接下来我们实现我们第一个Hello World

(1)导入依赖

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

(2)配置文件

spring:
  rabbitmq:
    host: IP地址
    username: guest
    password: guest
    port: 15672

(3)编写代码。“p”是生产者,“C”是消费者,中间是队列RabbitMQ作为消息缓冲区

生成者

public class Produce {
    // 队列名称
    public static final String QUEUE_NAME = "hello";
    // 发消息
    public static void main(String[] args) throws Exception {
        // 创建一个连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        // 创建连接
        Connection connection = factory.newConnection();
        // 获取信道
        Channel channel = connection.createChannel();
        // 生成队列
        channel.queueDeclare(QUEUE_NAME,false,false,false,null);
        // 发消息
        String message = "hello world";

        /**
         * 信道发消息
         * 1、发送到那个交换机
         * 2、路由的key值是那个,以下是使用队列的名称
         * 3、其他参数信息
         * 4、发送消息的消息体
         */
        channel.basicPublish("",QUEUE_NAME,null,message.getBytes());
        System.out.println("消息已经发送。。。");
    }
}

消费者

package com.example.rabbitmqone;

import com.rabbitmq.client.*;

public class Consumer {
    public static final String QUEUE_NAME = "hello";

    public static void main(String[] args) throws Exception {
        // 创建一个连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        // 创建连接
        Connection connection = factory.newConnection();
        // 获取信道
        Channel channel = connection.createChannel();
        // 声明接收消息
        DeliverCallback deliverCallback = (consumerTag,message) -> {
            System.out.println(new String(message.getBody()));
        };
        // 取消消息时的回调
        CancelCallback cancelCallback = consumerTag -> {
            System.out.println("消息消费被中断");
        };
        /**
         * 消费者消费信息
         * 1、消费那个队列
         * 2、消费成功之后是否需要自动答应徒惹代表自动,false表示手动
         * 3、消费者未成功消费的回调
         * 4、消费者录取消费的回调
         */
        channel.basicConsume(QUEUE_NAME,true,deliverCallback,cancelCallback);
    }
}

更多文章收录于https://github.com/niutongg/JavaLeague

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值