RabbitMQ入门案例之Direct模式

前言

RabbitMQ的Direct模式是一种可以根据指定路由key,Exchang将消息发送到具有该路由key下的Queue下进行存储。也就类似于将数据写进指定数据库表中。这个路由Key可以类比为SQL语句中的:where routeKey = …

官方文档地址:https://www.rabbitmq.com/getstarted.html

什么是Direct模式

RabbitMQ中的Direct模式是一种消息传输模式,通常使用Direct Exchange(直连交换机)实现。

在Direct模式中,生产者将消息发送到交换机,并指定消息的Routing Key(路由键)。交换机会将Routing Key与队列绑定进行匹配,如果匹配成功,则将该消息路由到对应的队列中。如果没有匹配成功,该消息将被丢弃或返回给生产者。在Direct模式中,每个消息只能被一个消费者接收。

Direct模式常用于一对一的场景,例如订单管理系统中将订单分配给特定的处理队列。

通过使用Exchange和Routing Key来进行消息传输,Direct模式实现了消息的有选择性地路由,提高了消息传输的效率,减少了系统负载。
在这里插入图片描述

实操

实操准备工作

在开始使用代码进行操作前,我们先到管理界面构造一个Direct交换机,如下图:
在这里插入图片描述
为其绑定Queue,同时设置这个Queue的route key,如下图:
在这里插入图片描述
最终绑定结果:
在这里插入图片描述
既然交换机和队列已经准备好,接下来就是准备依赖与代码了

<!--RabbitMQ依赖-->
<dependency>
	<groupId>com.rabbitmq</groupId>
	<artifactId>amqp-client</artifactId>
	<version>5.10.0</version>
</dependency>

生产者代码

public class Producer {
    public static void main(String[] args) {
        // 1: 创建连接工厂
        ConnectionFactory connectionFactory = new ConnectionFactory();
        // 2: 设置连接属性
        connectionFactory.setHost("ip地址");
        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();
            // 6: 准备发送消息的内容
            String message = "宇宙无敌爱学习";
            String  exchangeName = "direct_exchange";
            String routingKey1 = "class";
            String routingKey2 = "student";
            // 7: 发送消息给中间件rabbitmq-server
            // @params1: 交换机exchange
            // @params2: 队列名称/routingkey
            // @params3: 属性配置
            // @params4: 发送消息的内容
            channel.basicPublish(exchangeName, routingKey1, null, message.getBytes());
            channel.basicPublish(exchangeName, routingKey2, null, message.getBytes());
            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();
                }
            }
        }
    }
}

消费者代码

public class Consumer {
    private static Runnable runnable = () -> {
        // 1: 创建连接工厂
        ConnectionFactory connectionFactory = new ConnectionFactory();
        // 2: 设置连接属性
        connectionFactory.setHost("ip地址");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");
        connectionFactory.setUsername("guest");
        connectionFactory.setPassword("guest");
        //获取队列的名称
        final String queueName = Thread.currentThread().getName();
        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 可以设置队列附加参数,设置队列的有效期,消息的最大长度,队列的消息生命周期等等。
             * */
            // 这里如果queue已经被创建过一次了,可以不需要定义
            //channel.queueDeclare("queue1", false, false, false, null);
            // 6: 定义接受消息的回调
            Channel finalChannel = channel;
            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();
        } 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 && connection.isOpen()) {
                try {
                    connection.close();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
            }
        }
    };
    public static void main(String[] args) {
        // 启动三个线程去执行
        new Thread(runnable, "queue1").start();
        new Thread(runnable, "queue2").start();
        new Thread(runnable, "queue3").start();
    }
}

在生产者代码中,我们定义了两个route key,如下图:
在这里插入图片描述
在这两个路由key的驱使下,生产者的消息便只会被放到我们刚刚在direct_exchange交换机中具有这两个路由key的Queue中,我们来执行代码验证一下。

生产者执行结果
在这里插入图片描述
管理界面效果
在这里插入图片描述
可以看出,消息就只放进了queue2和queue3中,这是符合我们预期的。
消费者执行结果,如下:在这里插入图片描述
管理界面效果:
在这里插入图片描述
可以看出,消息也被成功取出去。

以上便是Direct模式的全部内容,仅个人笔记使用
感谢阅读
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
RabbitMQ是一款使用Erlang语言开发的开源消息中间件,它实现了AMQP(高级消息队列协议)。RabbitMQ具有以下特点: 1. 可靠性:支持持久化、传输确认和发布确认等机制,确保消息的可靠性。 2. 灵活的消息分发策略:通过Exchange(交换机)进行路由消息,支持简单模式、工作队列模式、发布订阅模式、路由模式和通配符模式等多种分发策略。 3. 支持集群:多台RabbitMQ服务器可以组成一个集群,形成一个逻辑的Broker。 4. 多种协议:RabbitMQ支持多种消息队列协议,如STOMP、MQTT等。 5. 多种语言客户端:RabbitMQ几乎支持所有常用编程语言,包括Java、.NET、Ruby等。 6. 可视化管理界面:RabbitMQ提供了一个易用的用户界面,方便用户监控和管理消息Broker。 7. 插件机制:RabbitMQ提供了许多插件,可以通过插件进行扩展,也可以编写自己的插件。 要入门RabbitMQ,您可以按照以下步骤: 1. 安装RabbitMQ:根据操作系统的不同,您可以按照相应的方式进行安装。例如,在Windows 10系统中,您可以通过双击rabbitmq-server.bat启动脚本来启动RabbitMQ。 2. 学习基础概念:了解什么是消息队列以及为什么使用消息队列。 3. 学习RabbitMQ的特点和组成部分:深入了解RabbitMQ的可靠性、消息分发策略等特点。 4. 学习RabbitMQ的工作流程:了解消息在RabbitMQ中的传递和处理过程。 5. 完成一个HelloWorld小案例:尝试使用RabbitMQ发送和接收简单的消息,以便熟悉RabbitMQ的基本用法。 6. 学习RabbitMQ交换机的四种类型的特点和使用方法:了解直连交换机、扇形交换机、主题交换机和头交换机的不同特点和使用场景。 通过以上步骤,您可以初步入门RabbitMQ,并开始使用它进行消息传递和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

摸鱼儿hzj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值