zoukankan      html  css  js  c++  java
  • RabbitMQ绑定、队列、消息、虚拟主机详解(五)

    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

  • 相关阅读:
    hql 链接查询
    Spring事务配置的五种方式
    web学习:Spring2.5+Hibernate3.3+Struts1.3整合小例子
    Strut2 spring hibernate 整合
    Spring+Struts集成(方案一)
    Remember that ordinal parameters are 1-based!
    ssh传输出现encountered 1 errors during the transfer解决办法
    编程时 对 用途这个字段定义时 不要用using 这个英文
    You can't specify target table 'charge' for update in FROM clause
    Navicat数据存放位置和备份数据库路径设置
  • 原文地址:https://www.cnblogs.com/luhan777/p/11162649.html
Copyright © 2011-2022 走看看