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