}
/**
* 绑定队列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年大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
…(img-4iVqA3f9-1712534693395)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
[外链图片转存中…(img-3dOx4fW4-1712534693396)]