消息中间件介绍 RabbitMq Docker上安装
消息队列中间件简介
data:image/s3,"s3://crabby-images/149cf/149cf956da287e97495b70e3ff3663e364dd3815" alt=""
什么是rabbitMq
data:image/s3,"s3://crabby-images/b151b/b151b44e624b4da5b763b8bc6df2dd663fbbc61c" alt=""
data:image/s3,"s3://crabby-images/070b8/070b81c715553d0f0e634478542a649470bd71c6" alt=""
data:image/s3,"s3://crabby-images/14c55/14c559c6ce880ea4a9080e81e4d6a23ccdf79789" alt=""
架构图
data:image/s3,"s3://crabby-images/8fc91/8fc91970df26e2b95705d9571410c822e857f352" alt=""
主要概念
data:image/s3,"s3://crabby-images/de5dd/de5ddd5711a8462d920fd9ed93aa0cad21a1e4a2" alt=""
data:image/s3,"s3://crabby-images/6e90f/6e90f8c49ee505739726096353101f1209868847" alt=""
Docker下安装
下载镜像
data:image/s3,"s3://crabby-images/dffe1/dffe139c56cd4e76375541270532ad9bac92e0da" alt=""
创建容器
data:image/s3,"s3://crabby-images/e9d5b/e9d5bec534a96248a9232a743984bdf3ae23aea4" alt=""
data:image/s3,"s3://crabby-images/46c3a/46c3a1f9e63306324ed2430d35b8654bd07e1ffb" alt=""
打开网址: 进入 可以 看到下面的图片
data:image/s3,"s3://crabby-images/8e62d/8e62dc63ac487484c7f5671e5a503e3db6c6d340" alt=""
rabbitMq 的模式介绍:
Direcrt 模式
我们需要讲消息发送给唯一一个节点时候使用这种模式 这是最简单的一个模式:
data:image/s3,"s3://crabby-images/53c88/53c8801f902b94c8237d8b5df558e6c37fe30cdd" alt=""
但是这种模式需要注意下面几点:
data:image/s3,"s3://crabby-images/de1c4/de1c469e5a4331d7d82b5fba184a6524a0740d75" alt=""
我们来创建 一个队列: 创建 test 队列
data:image/s3,"s3://crabby-images/b30ae/b30ae87358f9a3ba28a760f997352c21930cc312" alt=""
其中的参数是:
data:image/s3,"s3://crabby-images/26649/2664948582f70801e12396ac567c6faba008eef6" alt=""
接下来我们先写一个简单的Direct模式:
1.首先创建一个模块 rabbitmq_demo
2.pom引入依赖
<dependency>
<groupId>com.tensquare</groupId>
<artifactId>tensquare_common</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
3.配置application.yml 加入配置文件
spring:
rabbitmq:
host: 192.168.1.123
server:
port: 9008
4.接下来创建 启动类
data:image/s3,"s3://crabby-images/4d06b/4d06b125e6db79b8038ad2cc80739daca5ccf8e6" alt=""
5.接下来创建 消费者
data:image/s3,"s3://crabby-images/78525/78525a8cba2d03a52c8dc73e79ad608582f50190" alt=""
6.最后我们写一个测试类
@RunWith(SpringRunner.class)
@SpringBootTest(classes = RabbitMqDemoApplication.class)
public class MqTest {
@Autowired
private RabbitTemplate rabbitTemplate;
@Test
public void testSend() {
rabbitTemplate.convertAndSend("test","我是测试信息");
}
}
7.测试 先启动程序 后启动测试类
观察打印输出
data:image/s3,"s3://crabby-images/41a41/41a41b5969933a0b9c738e251ca740c3ef28f1d4" alt=""
分裂模式 fanout
当我们需要讲消息一次发送给多个队列的时候需要使用到这个模式
data:image/s3,"s3://crabby-images/4bfeb/4bfeb2fc04514a82fa65f7b382ec7fb1a9c7fab6" alt=""
但是需要注意下面的几点:
data:image/s3,"s3://crabby-images/c984c/c984cafe3fc9b1e9825e2a43e463fcff74828b61" alt=""
接下来我们需要 创建交换器 名字是testexchange
data:image/s3,"s3://crabby-images/ed77d/ed77d743093504b75ac79ad1e653fbd2bbbaeb40" alt=""
之后你会发现 在交换器列表出现了此交换器
data:image/s3,"s3://crabby-images/0457d/0457dc3bd9d20f82e28378c97620e64328fec949" alt=""
接下来我们要创建两个队列
data:image/s3,"s3://crabby-images/4a77d/4a77d3be097a1a9bbcc46d71c7e67728d735fa4d" alt=""
进入 交换机的配置页面
data:image/s3,"s3://crabby-images/e8801/e8801f46a2de115da9499f4832092796ad944553" alt=""
将我们想要配置的那两个队列配置到交换器上面
data:image/s3,"s3://crabby-images/6f226/6f226a8c8bbf725988d11cb69c19d82c0dcc7777" alt=""
接下来我们写代码 :
第一个队列 消费者
@Component
@RabbitListener(queues = "testexchangequeue")
@Slf4j
public class Customer2 {
@RabbitHandler
public void showMessage(String message) {
log.info("testexchangequeue队列收到的消息"+message);
}
}
第二个队列 消费者
@Slf4j
@Component
@RabbitListener(queues ="xxx" )
public class Customer3 {
@RabbitHandler
public void showMessage(String msg) {
log.info("xxx队列收到的消息" + msg);
}
}
测试类发送消息:
@Test
public void testSendFanout() {
System.out.println("fanout已经分发");
rabbitTemplate.convertAndSend("testexchange",null,"fanout模式发送的消息");
}
测试结果如下: 两个队列都收到了消息。
data:image/s3,"s3://crabby-images/53918/5391892e0ac97114108cade7cd490ada69c6ca0c" alt=""
主题模式 topic
data:image/s3,"s3://crabby-images/2e625/2e625cbd8d3a0df73eb488ce1d3b8a12f60d4a1a" alt=""
主题模式很复杂 有很多注意点 需要我们注意:
data:image/s3,"s3://crabby-images/59675/596757157ad0213babfd7c47d9bef6eb2d3ff2ab" alt=""
data:image/s3,"s3://crabby-images/5ab5a/5ab5aac8b2a542467468d8c1573e2803dd06a77a" alt=""
我们先来创建一个交换器 类型选择 tocpic
data:image/s3,"s3://crabby-images/4fa77/4fa7771a1ed68be19bbbb156e98f8a610913d5d7" alt=""
进入设置 进行配置 记得要配置 规则 routingKey
data:image/s3,"s3://crabby-images/ad948/ad9483f5a2e9075025b579e5cdd52aee06ebac95" alt=""
如上图 一共绑定了三个队列 并定了三个规则
编写测试类 也就是发送消息的 测试类 :
@Test
public void testSendTop1() {
rabbitTemplate.convertAndSend("topictest","goods.aaa","test 。。 goods.# 。。 topic");
}
@Test
public void testSendTop2() {
rabbitTemplate.convertAndSend("topictest","xx.log"," testexchangequeue 。。 #.log .. topic ");
}
@Test
public void testSendTop3() {
rabbitTemplate.convertAndSend("topictest", "goods.log", "xxx 。。goods.log 。。 topic ");
}
分别测试 结果如下所示:
testSendTop1 :
data:image/s3,"s3://crabby-images/c7405/c7405ac6e89b964263b85a645dea904597dec7c7" alt=""
testSendTop2:
data:image/s3,"s3://crabby-images/0c837/0c837b15f8f23f276ce273ac646b2f1e0c06b91f" alt=""
testSendTop3 结果 三个队列都收到消息了
data:image/s3,"s3://crabby-images/b5180/b51804a5df93b3067f377cbea890faf321615d39" alt=""