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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM