RabbitMQ入门案例 - Simple 简单模式(四)

01、实现步骤

1:jdk1.8
2:构建一个maven工程
3:导入rabbitmq的maven依赖
4:启动rabbitmq-server服务
5:定义生产者
6:定义消费者
7:观察消息的在rabbitmq-server服务中的过程

02、构建一个maven工程

在这里插入图片描述

03、导入rabbitmq的maven依赖

03-1:Java原生依赖

<dependency>   
	 <groupId>com.rabbitmq</groupId>    
	 <artifactId>amqp-client</artifactId>   
	 <version>5.10.0</version>
</dependency>

03-2:spring依赖

<dependency>    
	<groupId>org.springframework.amqp</groupId>   
	<artifactId>spring-amqp</artifactId>    
	<version>2.2.5.RELEASE</version>
</dependency>
<dependency>    
	<groupId>org.springframework.amqp</groupId>    
	<artifactId>spring-rabbit</artifactId>    
	<version>2.2.5.RELEASE</version>
</dependency>

03-3、springboot依赖

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

上面根据自己的项目环境进行选择即可。

番外:rabbitmq和spring同属一个公司开放的产品,所以他们的支持也是非常完善,这也是为什么推荐使用rabbitmq的一个原因。

04、启动rabbitmq-server服务

systemctl start rabbitmq-server或者docker start myrabbit

05、定义生产者

package simple;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
/**
 * @author: 学相伴-飞哥
 * @description: Producer 简单队列生产者
 * @Date : 2021/3/2
 */
public class Producer {
    public static void main(String[] args) {
        // 1: 创建连接工厂
        ConnectionFactory connectionFactory = new ConnectionFactory();
        // 2: 设置连接属性
        connectionFactory.setHost("192.168.229.128");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");
        connectionFactory.setUsername("guest");
        connectionFactory.setPassword("guest");
        Connection connection = null;
        Channel channel = null;
        try {
            // 3: 从连接工厂中获取连接
            connection = connectionFactory.newConnection("生产者");
            // 4: 从连接中获取通道channel
            channel = connection.createChannel();
            // 5: 申明队列queue存储消息
            /*
             *  如果队列不存在,则会创建
             *  Rabbitmq不允许创建两个相同的队列名称,否则会报错。
             *
             *  @params1: queue 队列的名称
             *  @params2: durable 队列是否持久化
             *  @params3: exclusive 是否排他,即是否私有的,如果为true,会对当前队列加锁,其他的通道不能访问,并且连接自动关闭
             *  @params4: autoDelete 是否自动删除,当最后一个消费者断开连接之后是否自动删除消息。
             *  @params5: arguments 可以设置队列附加参数,设置队列的有效期,消息的最大长度,队列的消息生命周期等等。
             * */
            channel.queueDeclare("queue1", false, false, false, null);
            // 6: 准备发送消息的内容
            String message = "你好,学相伴!!!";
            // 7: 发送消息给中间件rabbitmq-server
            // @params1: 交换机exchange
            // @params2: 队列名称/routing
            // @params3: 属性配置
            // @params4: 发送消息的内容
            channel.basicPublish("", "queue1", null, message.getBytes());
            System.out.println("消息发送成功!");
            System.in.read();
        } catch (Exception ex) {
            ex.printStackTrace();
            System.out.println("发送消息出现异常...");
        } finally {
            // 7: 释放连接关闭通道
            if (channel != null && channel.isOpen()) {
                try {
                    channel.close();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
            }
            if (connection != null) {
                try {
                    connection.close();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
            }
        }
    }
}

1:执行发送,这个时候可以在web控制台查看到这个队列queue的信息
在这里插入图片描述
在这里插入图片描述
2:我们可以进行对队列的消息进行预览和测试如下:
在这里插入图片描述
3:进行预览和获取消息进行测试
在这里插入图片描述

06、定义消费者

package simple;
import com.rabbitmq.client.*;

import java.io.IOException;

/**
 * @author: 学相伴-飞哥
 * @description: Producer 简单队列生产者
 * @Date : 2021/3/2
 */
public class Consumer {
    public static void main(String[] args) {
        // 1: 创建连接工厂
        ConnectionFactory connectionFactory = new ConnectionFactory();
        // 2: 设置连接属性
        connectionFactory.setHost("192.168.229.128");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");
        connectionFactory.setUsername("guest");
        connectionFactory.setPassword("guest");
        Connection connection = null;
        Channel channel = null;
        try {
            // 3: 从连接工厂中获取连接
            connection = connectionFactory.newConnection("消費者");
            // 4: 从连接中获取通道channel
            channel = connection.createChannel();
            // 5: 申明队列queue存储消息
            /*
             *  如果队列不存在,则会创建
             *  Rabbitmq不允许创建两个相同的队列名称,否则会报错。
             *
             *  @params1: queue 队列的名称
             *  @params2: durable 队列是否持久化
             *  @params3: exclusive 是否排他,即是否私有的,如果为true,会对当前队列加锁,其他的通道不能访问,并且连接自动关闭
             *  @params4: autoDelete 是否自动删除,当最后一个消费者断开连接之后是否自动删除消息。
             *  @params5: arguments 可以设置队列附加参数,设置队列的有效期,消息的最大长度,队列的消息生命周期等等。
             * */
            // 6: 定义接受消息的回调
            Channel finalChannel = channel;
            String queueName = "queue1";
            finalChannel.basicConsume(queueName, true, new DeliverCallback() {
                @Override
                public void handle(String s, Delivery delivery) throws IOException {
                    System.out.println(queueName + ":收到消息是:" + new String(delivery.getBody(), "UTF-8"));
                }
            }, new CancelCallback() {
                @Override
                public void handle(String s) throws IOException {
                }
            });
            System.out.println(queueName + ":开始接受消息");
            System.in.read();

            System.out.println("接受消息成功!");
        } catch (Exception ex) {
            ex.printStackTrace();
            System.out.println("接受消息出现异常...");
        } finally {
            // 7: 释放连接关闭通道
            if (channel != null && channel.isOpen()) {
                try {
                    channel.close();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
            }
            if (connection != null) {
                try {
                    connection.close();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
            }
        }
    }
}

07、注意事项

本人rabbitmq服务器是搭建在远程机上的,而默认用户guest,在远程机上是可以直接访问的,但在本地机去访问远程机的rabbitmq时是没有权限的,因此需要重新给guest赋予远程访问权限。

### 关于RabbitMQ学习资料 #### 黑马程序员教程概述 黑马程序员提供了详尽的RabbitMQ入门到实战教程,涵盖了从基础概念至高级应用的内容。此教程不仅适合初学者理解基本原理,也适用于希望深入研究特定功能和技术细节的开发者[^1]。 #### 工作模式详解 该教程介绍了六种不同的工作模式简单模式、Work Queues(工作队列)、Publish/Subscribe(发布与订阅)、Routing(路由)、Topics(主题),以及RPC远程过程调用模式(虽然后者严格来说不属于消息队列范畴,在这里不做详细介绍)。每一种模式都有其适用场景和特点,通过实例帮助读者更好地掌握如何根据不同需求选择合适的消息传递方式[^2]。 #### 实践案例分享 为了加深理解和实际操作能力,教程中包含了多个实践案例。例如,在`testWorkQueue()`方法里展示了如何向指定队列持续发送大量消息来模拟真实环境下的消息堆积情况。这段代码片段可以帮助开发人员熟悉API接口并测试系统的性能边界: ```java @Test public void testWorkQueue() throws InterruptedException { // 队列名称 String queueName = "simple.queue"; // 消息前缀 String messagePrefix = "hello, message_"; for (int i = 0; i < 50; i++) { // 构建具体消息内容 String fullMessage = messagePrefix + i; // 使用rabbitTemplate对象将消息发送给目标队列 rabbitTemplate.convertAndSend(queueName, fullMessage); // 添加短暂延时以观察效果 Thread.sleep(20); } } ``` 上述代码实现了向名为`simple.queue`的目标队列连续发送带有编号的消息的功能,并且每次发送之间有轻微的时间间隔以便更直观地看到消息入队的过程[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值