目录
(3.4.2)基础消息队列(RabbitTemplate模板实现)。
[(3.4.3)work Queue工作队列。](#(3.4.3)work Queue工作队列。)
[(3.4.4)发布订阅-Fanout Exchange。](#(3.4.4)发布订阅-Fanout Exchange。)
一、MQ---RabbitMQ。
(1)同步调用与异步调用。
(1.1)同步调用。
data:image/s3,"s3://crabby-images/87411/87411f0ddbce1c18879d595dec706577fb0013ea" alt=""
(1.2)异步调用。
data:image/s3,"s3://crabby-images/9c851/9c85121dacb74fbe03ecaa4bb0d43f99ad6d3541" alt=""
(2)MQ之间的区别。
data:image/s3,"s3://crabby-images/d17f3/d17f38bb7545a2625a653f0449faf7b2bf864df0" alt=""
(3)RabbitMQ学习。
(3.1)docker下载rabbitmq容器,并启动。
下载容器:
docker pull rabbitmq:3-management
启动容器:
docker run \
-e RABBITMQ_DEFAULT_USER=itcast \
-e RABBITMQ_DEFAULT_PASS=123321 \
--name mq \
--hostname mq1 \
-p 15672:15672 \
-p 5672:5672 \
-d \
rabbitmq:3-management
浏览器访问:
data:image/s3,"s3://crabby-images/260d7/260d7ebed78c09423cde30cae3927fe9731c7273" alt=""
(3.2)RabbitMQ中的几个概念。
data:image/s3,"s3://crabby-images/5fe53/5fe53be6e4b4eca6a828cd784b8f0f86ced637b7" alt=""
(3.3)常见消息模型。
data:image/s3,"s3://crabby-images/82c59/82c59ba781a8f10bf78393b8bf64219481d05cd4" alt=""
(3.4)常见消息模型学习。
提示:AMQP是协议,SpringAMQP是基于AMQP实现的一套API。
data:image/s3,"s3://crabby-images/f2b59/f2b5935cbb778c7cf1ffbfe5594c3ec79ec2db8d" alt=""
(3.4.1)基础消息队列(代码实现)。
消息发送:
java
public class PublisherTest {
@Test
public void testSendMessage() throws IOException, TimeoutException {
// 1.建立连接
ConnectionFactory factory = new ConnectionFactory();
// 1.1.设置连接参数,分别是:主机名、端口号、vhost、用户名、密码
factory.setHost("192.168.150.101");
factory.setPort(5672);
factory.setVirtualHost("/");
factory.setUsername("itcast");
factory.setPassword("123321");
// 1.2.建立连接
Connection connection = factory.newConnection();
// 2.创建通道Channel
Channel channel = connection.createChannel();
// 3.创建队列
String queueName = "simple.queue";
channel.queueDeclare(queueName, false, false, false, null);
// 4.发送消息
String message = "hello, rabbitmq!";
channel.basicPublish("", queueName, null, message.getBytes());
System.out.println("发送消息成功:【" + message + "】");
// 5.关闭通道和连接
channel.close();
connection.close();
}
}
消息接收:
java
public class ConsumerTest {
public static void main(String[] args) throws IOException, TimeoutException {
// 1.建立连接
ConnectionFactory factory = new ConnectionFactory();
// 1.1.设置连接参数,分别是:主机名、端口号、vhost、用户名、密码
factory.setHost("192.168.150.101");
factory.setPort(5672);
factory.setVirtualHost("/");
factory.setUsername("itcast");
factory.setPassword("123321");
// 1.2.建立连接
Connection connection = factory.newConnection();
// 2.创建通道Channel
Channel channel = connection.createChannel()
// 3.创建队列
String queueName = "simple.queue";
channel.queueDeclare(queueName, false, false, false, null);
// 4.订阅消息
channel.basicConsume(queueName, true, new DefaultConsumer(channel){
@Override
public void handleDelivery(String consumerTag, Envelope envelope,
AMQP.BasicProperties properties, byte[] body) throws IOException {
// 5.处理消息
String message = new String(body);
System.out.println("接收到消息:【" + message + "】");
}
});
System.out.println("等待接收消息。。。。");
}
}
data:image/s3,"s3://crabby-images/a254a/a254a4cc4d3d154d65b3724beb92b5abbe592a85" alt=""
(3.4.2)基础消息队列(RabbitTemplate模板实现)。
data:image/s3,"s3://crabby-images/4aa5f/4aa5f7b0f190c5379a28ca08129e936e2f859823" alt=""
(3.4.3)work Queue工作队列。
与simple的区别:多了一个设置消费预存限制。
data:image/s3,"s3://crabby-images/db59c/db59c9551dab405e7802a94553026476dfc4e5ec" alt=""
(3.4.4)发布订阅**-FanoutExchange。**
提示:绑定键使用空字符串,就可以完成广播(发给所有绑定该交换机的队列)。
data:image/s3,"s3://crabby-images/fec07/fec07907e77e8be8c1ca0d2a6c6061be2e3c83a9" alt=""
(3.4.5)发布订阅**-**DirectExchange。
提示:需要提供绑定键(路由键),根据 交换机+绑定键 映射。
data:image/s3,"s3://crabby-images/93696/93696d91416a6efaad5fe522a1fb4d655282a5e4" alt=""
(3.4.6)发布订阅**-**TopicExchange。
data:image/s3,"s3://crabby-images/92e16/92e16cf8727019206e4fd4dd292ff89d4a170c0f" alt=""
(3.5)消息转换器。
data:image/s3,"s3://crabby-images/34835/34835f58d856e06a3203e1dea0a1db1ce38ec3d4" alt=""