0.Binding-绑定
Exchange和Exchange、Queue之间的连接关系。
1.Queue-消息队列
消息队列,实际存储消息数据。
Durability:是否持久化,Durable:是,Transient:否
Auto delete:如选yes,代表当最后一个监听被移除之后,该Queue会被自动删除
2.Message-消息
服务器和应用之间传送的消息
本质上就是一段数据,由Properties和Payload(Body)组成
常用属性:delivery mode、headers(自定义属性)
其他属性:content_type、content_ encoding、priority
correlation_id、replay_to、message_id
timestamp、type、user_id、app_id、cluster_id
3.Virtual host-虚拟机
虚拟地址,用于进行逻辑隔离,最上层的消息路由
一个Virtual host里面可以有若干个Exchange和Queue
同一个Virtual host里面不能有系统名称的Exchange和Queue
4.关于消息的demo
获取连接相关的代码和之前demo一样
4.1 生产者代码
package com.star.movie.message;
import com.rabbitmq.client.AMQP;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.star.movie.common.Constant;
import java.util.HashMap;
import java.util.Map;
/**
* @Description:Procuder
* @author:kaili
* @Date: 2019-04-21 23:05
**/
public class MessageProducer {
public static void main(String[] args) throws Exception {
//2 通过连接工厂创建连接
Connection connection = Constant.getConnection();
//3 通过connection创建一个Channel
Channel channel = connection.createChannel();
Map<String, Object> headers = new HashMap<>();
headers.put("my1", "111");
headers.put("my2", "222");
AMQP.BasicProperties properties = new AMQP.BasicProperties.Builder()
.deliveryMode(2)
.contentEncoding("UTF-8")
.expiration("50000")
.headers(headers)
.build();
//4 通过Channel发送数据
for(int i=0; i < 5; i++){
String msg = "Hello RabbitMQ!";
//1 exchange 2 routingKey
channel.basicPublish("", "test001", properties, msg.getBytes());
}
//5 记得要关闭相关的连接
channel.close();
connection.close();
}
}
4.2 消费者代码
package com.star.movie.message;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.QueueingConsumer;
import com.rabbitmq.client.QueueingConsumer.Delivery;
import com.star.movie.common.Constant;
import java.util.Map;
/**
* @Description:Consumer
* @author:kaili
* @Date: 2019-04-21 23:06
**/
public class MessageConsumer {
public static void main(String[] args) throws Exception {
//2 通过连接工厂创建连接
Connection connection = Constant.getConnection();
//3 通过connection创建一个Channel
Channel channel = connection.createChannel();
//4 声明(创建)一个队列
String queueName = "test001";
channel.queueDeclare(queueName, true, false, false, null);
//5 创建消费者
QueueingConsumer queueingConsumer = new QueueingConsumer(channel);
//6 设置Channel
channel.basicConsume(queueName, true, queueingConsumer);
while(true){
//7 获取消息
Delivery delivery = queueingConsumer.nextDelivery();
String msg = new String(delivery.getBody());
System.err.println("消费端: " + msg);
Map<String, Object> headers = delivery.getProperties().getHeaders();
System.err.println("headers get my1 value: " + headers.get("my1"));
//Envelope envelope = delivery.getEnvelope();
}
}
}
4.3 启动项目
首先启动消费者代码
然后启动生产者代码
观察消费者的控制台
head中封装的消息在消费者端获取到了