Java最新每日一学:如何在RabbitMQ中搭建Topics通配符模式(2),java面试刷题pdf

最后

作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料


本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

①生产者

使用topic类型的Exchange,发送消息的routing key有3种: item.insertitem.updateitem.delete

package com.itheima.rabbitmq.topic;

import com.itheima.rabbitmq.util.ConnectionUtil;
import com.rabbitmq.client.BuiltinExchangeType;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;

/**

  • 通配符Topic的交换机类型为:topic
    */
    public class Producer {
    //交换机名称
    static final String TOPIC_EXCHAGE = “topic_exchange”;

//队列名称
static final String TOPIC_QUEUE_1 = “topic_queue_1”;

//队列名称
static final String TOPIC_QUEUE_2 = “topic_queue_2”;
public static void main(String[] args) throws Exception {
//创建连接
Connection connection = ConnectionUtil.getConnection();
// 创建频道
Channel channel = connection.createChannel();
/**

  • 声明交换机
  • 参数1:交换机名称
  • 参数2:交换机类型,fanout、topic、topic、headers
    */
    channel.exchangeDeclare(TOPIC_EXCHAGE, BuiltinExchangeType.TOPIC);

// 发送信息
String message = "新增了商品。Topic模式;routing key 为 item.insert " ;
channel.basicPublish(TOPIC_EXCHAGE, “item.insert”, null, message.getBytes());
System.out.println(“已发送消息:” + message);

// 发送信息
message = “修改了商品。Topic模式;routing key 为 item.update” ;
channel.basicPublish(TOPIC_EXCHAGE, “item.update”, null, message.getBytes());
System.out.println(“已发送消息:” + message);

// 发送信息
message = “删除了商品。Topic模式;routing key 为 item.delete” ;
channel.basicPublish(TOPIC_EXCHAGE, “item.delete”, null, message.getBytes());
System.out.println(“已发送消息:” + message);

// 关闭资源
channel.close();
connection.close();
}
}

②消费者1

接收两种类型的消息:更新商品和删除商品

package com.itheima.rabbitmq.topic;

import com.itheima.rabbitmq.util.ConnectionUtil;
import com.rabbitmq.client.*;
import java.io.IOException;

public class Consumer1 {
public static void main(String[] args) throws Exception {
Connection connection = ConnectionUtil.getConnection();

// 创建频道
Channel channel = connection.createChannel();

//声明交换机
channel.exchangeDeclare(Producer.TOPIC_EXCHAGE, BuiltinExchangeType.TOPIC);

// 声明(创建)队列
/**

  • 参数1:队列名称
  • 参数2:是否定义持久化队列
  • 参数3:是否独占本次连接
  • 参数4:是否在不使用的时候自动删除队列
  • 参数5:队列其它参数
    */
    channel.queueDeclare(Producer.TOPIC_QUEUE_1, true, false, false, null);

//队列绑定交换机
channel.queueBind(Producer.TOPIC_QUEUE_1, Producer.TOPIC_EXCHAGE, “item.update”);
channel.queueBind(Producer.TOPIC_QUEUE_1, Producer.TOPIC_EXCHAGE, “item.delete”);

//创建消费者;并设置消息处理
DefaultConsumer consumer = new DefaultConsumer(channel){
@Override
/**

  • consumerTag 消息者标签,在channel.basicConsume时候可以指定
  • envelope 消息包的内容,可从中获取消息id,消息routingkey,交换机,消息和重传标志(收到消息失败后是否需要重新发送)
  • properties 属性信息
  • body 消息
    */
    public void handleDelivery(String consumerTag, Envelope envelope,
    AMQP.BasicProperties properties, byte[] body) throws IOException {
    //路由key
    System.out.println(“路由key为:” + envelope.getRoutingKey());

//交换机
System.out.println(“交换机为:” + envelope.getExchange());

//消息id
System.out.println(“消息id为:” + envelope.getDeliveryTag());

//收到的消息
System.out.println(“消费者1-接收到的消息为:” + new String(body, “utf-8”));
}
};
//监听消息
/**

  • 参数1:队列名称
  • 参数2:是否自动确认,设置为true为表示消息接收到自动向mq回复接收到了,mq接收到回复会删除消息,设置为false则需要手动确认
  • 参数3:消息接收到后回调
    */
    channel.basicConsume(Producer.TOPIC_QUEUE_1, true, consumer);
    }
    }

③消费者2

接收所有类型的消息:新增商品,更新商品和删除商品。

package com.itheima.rabbitmq.topic;

import com.itheima.rabbitmq.util.ConnectionUtil;
import com.rabbitmq.client.*;
import java.io.IOException;

public class Consumer2 {
public static void main(String[] args) throws Exception {
Connection connection = ConnectionUtil.getConnection();

// 创建频道
Channel channel = connection.createChannel();

最后

如果觉得本文对你有帮助的话,不妨给我点个赞,关注一下吧!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

需要这份系统化的资料的朋友,可以点击这里获取

  • 22
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值