Binding:绑定,Exchange和Exchange、Queue之间的连接关系

    Binding中可以包含RoutingKey或者参数

Queue:消息队列,实际存储消息数据

    Durability:是否持久化,Durable:是,Transient:否

    Auto Delete:如选yes,代表当最后一个监听被移除之后,该Queue会自动被删除

Message:服务器和应用程序之间传送的数据

     本质上是一段数据,有Properties和Payload(Body)组成

     常用属性:delivery mode、headers(自定义属性)

     其他属性:content_type、content_encoding(字符集)、priority(消息优先级0-9,从小到大,优先级越来越高)

          correlation_id(消息唯一id)、reply_to(重回队列,返回哪个队列)、

          expiration(消息过期时间)、message_id(消息id)

          timestamp(时间戳)、type、user_id、app_id、cluster_id

            //生产者端代码

             //1 创建一个ConnectionFactory, 并进行配置
ConnectionFactory connectionFactory = new ConnectionFactory();
connectionFactory.setHost("127.0.0.1");
connectionFactory.setPort(5672);
connectionFactory.setVirtualHost("/"); //2 通过连接工厂创建连接
Connection connection = connectionFactory.newConnection(); //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("10000")
.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();
    //消费者端代码
//1 创建一个ConnectionFactory, 并进行配置
ConnectionFactory connectionFactory = new ConnectionFactory();
connectionFactory.setHost("127.0.0.1");
connectionFactory.setPort(5672);
connectionFactory.setVirtualHost("/"); //2 通过连接工厂创建连接
Connection connection = connectionFactory.newConnection(); //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();
}

Virtual Host:虚拟主机,用于进行逻辑隔离,最上层的消息路由

       一个Virtual Host里面可以有若干个Exchange和Queue

       同一个Virtual Host不能有相同名称的Exchange和Queue

最新文章

  1. Asp.Net 操作XML文件的增删改查 利用GridView
  2. java抽象、接口 和final
  3. Delphi XE5-XE8 以上 如何发布文件到工程中
  4. SQLAlchemy模型使用
  5. winform调用浏览器
  6. AC自动机---病毒侵袭
  7. 1.3查看Linux内核版本
  8. h-index
  9. 形形色色Node工程Angular2
  10. Visual Studio调试之避免单步跟踪调试模式
  11. VMware vSphere 6 Enterprise Plus License
  12. Quartz 2D官方文档翻译(持续更新中)
  13. CentOs6系统安装mailx发邮件
  14. 每天一个JS 小demo之留言板。主要知识点:DOM方法的理解和运用
  15. jquery.editable-select 可编辑下拉框之获取select值和input值
  16. SQLServer之创建非聚集索引
  17. Android studio下载慢解决,使用阿里云解决(转)
  18. MFC修改对话框标题
  19. fix
  20. Java Callable接口——有返回值的线程

热门文章

  1. python+selenium模拟鼠标操作
  2. express中app.use()使用方法
  3. Spark-Core RDD转换算子-双Value型交互
  4. Luogu P5330 [SNOI2019]数论
  5. 偶遇com组件 .rc 文件 not found .tlb文件问题:
  6. JetBrains下载历史版本
  7. T-聊天止于呵呵
  8. docker容器配置hosts
  9. Solr安装(单机版)
  10. Vue框架前言