SpringAMQP消息队列,大厂内部资料

}
/**
* 绑定队列1到交换机
*/
@Bean
public Binding fanoutBinding1(Queue fanoutQueue1, FanoutExchange fanoutExchange){
return BindingBuilder.bind(fanoutQueue1).to(fanoutExchange);
}
@Bean
public Queue fanoutQueue2(){
return new Queue(“fanout.queue2”);
}
/**
* 绑定队列2到交换机
*/
@Bean
public Binding fanoutBinding2(Queue fanoutQueue2, FanoutExchange fanoutExchange){
return BindingBuilder.bind(fanoutQueue2).to(fanoutExchange);
}
}

  • 监听队列1和队列2

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Component
public class MyRabbitListener {

@RabbitListener(queues = “fanout.queue1”)
public void listenFanoutQueue1(String msg){
System.out.println(“消费者接收到fanout.queue1的消息: {” + msg + “}”);
}

@RabbitListener(queues = “fanout.queue2”)
public void listenFanoutQueue2(String msg){
System.out.println(“消费者接收到fanout.queue2的消息: {” + msg + “}”);
}
}

  • 发布消息

@Test
void name() {
String exchangeName = “itcast.fanout”;
String message = “hello , everyone!”;
rabbitTemplate.convertAndSend(exchangeName, “”, message);
}

  • 运行结果

在这里插入图片描述
缺点:
不能缓存消息, 路由失败, 消息丢失

Direct Exchange

在这里插入图片描述

  • 绑定

import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Component
public class MyRabbitListener {

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = “direct.queue1”),
exchange = @Exchange(name = “zhouyu.direct”, type = ExchangeTypes.DIRECT),
key = {“red”, “blue”}))
public void listenDirectQueue1(String msg){
System.out.println(“消费者1接收到direct的消息: [” + msg + “]”);
}

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = “direct.queue2”),
exchange = @Exchange(name = “zhouyu.direct”, type = ExchangeTypes.DIRECT),
key = {“red”, “yellow”}))
public void listenDirectQueue2(String msg){
System.out.println(“消费者2接收到direct的消息: [” + msg + “]”);
}
}

  • 发布消息

@Test
void name() {
String exchangeName = “zhouyu.direct”;
String message = “hello red”;
rabbitTemplate.convertAndSend(exchangeName, “red”, message);
}

Topic Exchange

在这里插入图片描述

  • 绑定

import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Component
public class MyRabbitListener {

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = “topic.queue1”),
exchange = @Exchange(name = “zhouyu.topic”, type = ExchangeTypes.TOPIC),
key = “china.#”))
public void listenTopicQueue1(String msg){
System.out.println(“消费者1接收到topic1的消息: [” + msg + “]”);
}

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = “topic.queue2”),
exchange = @Exchange(name = “zhouyu.topic”, type = ExchangeTypes.TOPIC),
key = “#.news”))
public void listenTopicQueue2(String msg){
System.out.println(“消费者2接收到topic2的消息: [” + msg + “]”);
}
}

  • 发布消息

@Test
void name() {
String exchangeName = “zhouyu.topic”;
String message = “china.weather”;
rabbitTemplate.convertAndSend(exchangeName, “china.weather”, message);
}

基于bean实现topic


  • MqConstants.java

public class MqConstants {

public static final String HOTEL_EXCHANGE = “hotel.topic”;
public static final String HOTEL_INSERT_QUEUE = “hotel.insert.queue”;
public static final String HOTEL_DELETE_QUEUE = “hotel.delete.queue”;
public static final String HOTEL_INSERT_KEY = “hotel.insert.key”;
public static final String HOTEL_DELETE_KEY = “hotel.delete.key”;

}

  • MqConfig.java

import cn.zyw.MqConstants;
import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.TopicExchange;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MqConfig {

@Bean
public TopicExchange topicExchange(){
return new TopicExchange(MqConstants.HOTEL_EXCHANGE, true, false);
}

@Bean
public Queue insertQueue(){
return new Queue(MqConstants.HOTEL_INSERT_QUEUE, true);
}

@Bean
public Queue deleteQueue(){
return new Queue(MqConstants.HOTEL_DELETE_QUEUE, true);
}

@Bean
public Binding insertQueueBinding(){
return BindingBuilder.bind(insertQueue()).to(topicExchange()).with(MqConstants.HOTEL_INSERT_KEY);
}

@Bean
public Binding deleteQueueBinding(){
return BindingBuilder.bind(deleteQueue()).to(topicExchange()).with(MqConstants.HOTEL_DELETE_KEY);
}
}

  • HotelListener.java

import cn.zyw.MqConstants;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Component
public class HotelListener {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数大数据工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
img

…(img-4iVqA3f9-1712534693395)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
[外链图片转存中…(img-3dOx4fW4-1712534693396)]

  • 10
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值