【RabbitMQ】4、Java中整合RabbitMQ的使用

简介: 本次,我们以IDEA + SpringBoot作为 Java中整合Redis的使用 的测试环境。

一、引入 MQ 的依赖

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

二、配置文件中写入 MQ 的配置信息

#rabbitmq 配置信息
spring:
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    username: guest
    password: guest

三、创建生产者

package com.zyxx.rabbitmq.entity;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
/**
 * @ClassName producer
 * 生产者
 * @Author Lizhou
 * @Date 2019-08-02 9:54:54
 * @Version 1.0
 **/
public class ProducerTest {
    public static void main(String[] args) {
        // 创建一个连接工厂,用于生成与RabbitMQ进行连接
        ConnectionFactory factory = new ConnectionFactory();
        // 根据这个连接工厂设置RabbitMQ所在的主机,账号密码和端口号等(默认情况下就不需要账号密码和端口了)
        factory.setHost(MqEntity.HOST);
        factory.setUsername(MqEntity.USERNAME);
        factory.setPassword(MqEntity.PASSWORD);
        try {
            // 由连接工厂生成与RabbitMQ的连接
            Connection connection = factory.newConnection();
            // 创建一条通道
            Channel newChannel = connection.createChannel();
            // 由这个通道声明一个队列
            newChannel.queueDeclare(MqEntity.QUEUENAME, false, false, true, null);
            // 要发送的消息
            String sendMessage = "Hello,我是生产者!!!";
            newChannel.basicPublish(MqEntity.EXCHANGE_NAME, MqEntity.QUEUENAME, null, sendMessage.getBytes());
            System.out.println("消息发送成功!!!");
            // 关闭通道
            newChannel.close();
            // 关闭连接
            connection.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

四、创建消费者

package com.zyxx.test;
import com.rabbitmq.client.*;
import java.io.IOException;
/**
 * @ClassName Consumer
 * 消费者
 * @Author Lizhou
 * @Date 2019-08-02 9:57:57
 * @Version 1.0
 **/
public class ConsumerTest {
    public static void main(String[] args) {
        // 创建一个连接工厂,用于生成与RabbitMQ进行连接
        ConnectionFactory factory=new ConnectionFactory();
        // 根据这个连接工厂设置RabbitMQ所在的主机,账号密码和端口号等(默认情况下就不需要账号密码和端口了)
        factory.setHost(MqEntity.HOST);
        factory.setUsername(MqEntity.USERNAME);
        factory.setPassword(MqEntity.PASSWORD);
        Connection connection;
        try {
            // 创建一条通道,通道创建好后,关联相关的队列
            connection = factory.newConnection();
            Channel newChannel = connection.createChannel();
            newChannel.queueDeclare(MqEntity.QUEUENAME, false, false, true, null);
            Consumer consumer = new DefaultConsumer(newChannel){
                // 重写handleDelivery方法
                @Override
                public void handleDelivery(String consumerTag, Envelope envelope, 
                                           AMQP.BasicProperties properties, byte[] body) throws IOException {
                    String getMessage = new String(body, "UTF-8");
                    System.out.println("接收到消息:'" + getMessage + "'");
                }
            };
            // 自动回复队列应答 -- RabbitMQ中的消息确认机制
            newChannel.basicConsume(MqEntity.QUEUENAME, true, consumer);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

五、创建 MQ 常量类

package com.zyxx.test;
/**
 * @author lizhou
 * @date 2019-08-02
 */
public final class MqEntity {
    /**
     * 队列名称
     */
    public final static String QUEUENAME="mq.test_queu1";
    /**
     * 主机名
     */
    public final  static String HOST="localhost";
    /**
     * 用户名
     */
    public final static  String USERNAME="guest";
    /**
     * 密码
     */
    public final static  String PASSWORD="guest";
    /**
     * 交换机名
     */
    public final static  String EXCHANGE_NAME="";
}
  • 六、启动生产者,发送消息

消息发送成功!!!

  • 七、启动消费者,接收消息

接收到消息:‘Hello,我是生产者!!!’

最后,你还可以创建两个 SpringBoot 项目,一边用来发,一边用来收,可实现实时通信。

相关实践学习
RocketMQ一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
2天前
|
消息中间件 前端开发 Java
java面试刷题软件kafka和mq的区别面试
java面试刷题软件kafka和mq的区别面试
|
4天前
|
消息中间件 Java
Java操作RabbitMQ单一生产-消费者模式
Java操作RabbitMQ单一生产-消费者模式
32 0
|
3天前
|
消息中间件 Java RocketMQ
MQ产品使用合集之在同一个 Java 进程内建立三个消费对象并设置三个消费者组订阅同一主题和标签的情况下,是否会发生其中一个消费者组无法接收到消息的现象
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
10 1
|
4天前
|
消息中间件 Java API
RabbitMQ入门指南(五):Java声明队列、交换机以及绑定
RabbitMQ是一个高效、可靠的开源消息队列系统,广泛用于软件开发、数据传输、微服务等领域。本文主要介绍了Java声明队列、交换机以及绑定队列和交换机等内容。
36 0
|
4天前
|
消息中间件 Java API
RabbitMQ入门指南(三):Java入门示例
RabbitMQ是一个高效、可靠的开源消息队列系统,广泛用于软件开发、数据传输、微服务等领域。本文主要介绍了AMQP、Spring AMQP和使用SpringAMQP实现对RabbitMQ的消息收发等内容。
33 0
RabbitMQ入门指南(三):Java入门示例
|
4天前
|
Java Maven Android开发
java如何连接mqtt
java如何连接mqtt
89 0
|
6月前
|
消息中间件 存储 Java
Java面试题 -RocketMQ
Java面试题 -RocketMQ
63 0
|
6月前
|
消息中间件 存储 网络协议
Java面试题 -RabbitMQ
Java面试题 -RabbitMQ
65 0
|
4天前
|
消息中间件 Java Unix
一文搞懂Java整合RocketMQ
一文搞懂Java整合RocketMQ
71 1
|
4天前
|
消息中间件 Java RocketMQ
RocketMQ-初体验RocketMQ(11)-过滤消息_自定义Java类筛选消息
RocketMQ-初体验RocketMQ(11)-过滤消息_自定义Java类筛选消息
38 0
RocketMQ-初体验RocketMQ(11)-过滤消息_自定义Java类筛选消息