rabbitMQ學習筆記(五) 消息路由

生產者會生產出很多消息 , 但是不同的消費者可能會有不同的需求,只需要接收指定的消息,其他的消息需要被過濾掉。 這時候就可以對消息進行過濾了。 在消費者端設置好需要接收的消息類型。


如果不使用默認的Exchange發送消息,而是使用我們自定定義的Exchange發送消息,那麼下面這個方法的第二個參數就不是QueueName了,而是消息的類型。

channel.basicPublish( exchangeName , messageType , null , msg.getBytes());


示例:Sender05.java

[java] view plaincopy
  1. package com.zf.rabbitmq05;  
  2.   
  3. import java.io.IOException;  
  4.   
  5. import com.rabbitmq.client.Channel;  
  6. import com.rabbitmq.client.Connection;  
  7. import com.rabbitmq.client.ConnectionFactory;  
  8.   
  9. /** 
  10.  * 發送消息 
  11.  * @author zhoufeng 
  12.  * 
  13.  */  
  14. public class Sender05 {  
  15.       
  16.     public static void main(String[] args) throws IOException {  
  17.           
  18.         ConnectionFactory connFac = new ConnectionFactory() ;  
  19.           
  20.         //RabbitMQ-Server安裝在本機,所以直接用127.0.0.1  
  21.         connFac.setHost("127.0.0.1");  
  22.           
  23.         //創建一個連接  
  24.         Connection conn = connFac.newConnection() ;  
  25.           
  26.         //創建一個渠道  
  27.         Channel channel = conn.createChannel() ;  
  28.           
  29.         String exchangeName = "exchange02";  
  30.           
  31.         String messageType = "type01";  
  32.           
  33.         channel.exchangeDeclare(exchangeName, "direct") ;  
  34.           
  35.         //定義Queue名  
  36.         String msg = "Hello World!";  
  37.           
  38.         //發送消息  
  39.         channel.basicPublish( exchangeName , messageType , null , msg.getBytes());  
  40.           
  41.         System.out.println("send message[" + msg + "] to "+ exchangeName +" success!");  
  42.           
  43.         channel.close();   
  44.         conn.close();   
  45.           
  46.     }  
  47.   
  48. }  

[java] view plaincopy
  1. package com.zf.rabbitmq05;  
  2.   
  3. import java.io.IOException;  
  4.   
  5. import com.rabbitmq.client.Channel;  
  6. import com.rabbitmq.client.Connection;  
  7. import com.rabbitmq.client.ConnectionFactory;  
  8. import com.rabbitmq.client.ConsumerCancelledException;  
  9. import com.rabbitmq.client.QueueingConsumer;  
  10. import com.rabbitmq.client.QueueingConsumer.Delivery;  
  11. import com.rabbitmq.client.ShutdownSignalException;  
  12.   
  13. /** 
  14.  * 接收消息 
  15.  * @author zhoufeng 
  16.  * 
  17.  */  
  18. public class Recv05_01 {  
  19.   
  20.     public static void main(String[] args) throws IOException, ShutdownSignalException, ConsumerCancelledException, InterruptedException {  
  21.           
  22.         ConnectionFactory connFac = new ConnectionFactory() ;  
  23.           
  24.         connFac.setHost("127.0.0.1");  
  25.           
  26.         Connection conn = connFac.newConnection() ;  
  27.           
  28.         Channel channel = conn.createChannel() ;  
  29.           
  30.           
  31.         String exchangeName = "exchange02";  
  32.           
  33.         channel.exchangeDeclare(exchangeName, "direct") ;  
  34.           
  35.         String queueName = channel.queueDeclare().getQueue() ;  
  36.           
  37.         //第三個參數就是type,這裏表示只接收type01類型的消息。  
  38.         channel.queueBind(queueName, exchangeName, "type01") ;  
  39.         //也可以選擇接收多種類型的消息。只需要再下面再綁定一次就可以了  
  40.         channel.queueBind(queueName, exchangeName, "type02") ;  
  41.           
  42.           
  43.         //配置好獲取消息的方式  
  44.         QueueingConsumer consumer = new QueueingConsumer(channel) ;  
  45.         channel.basicConsume(queueName, true, consumer) ;  
  46.           
  47.         //循環獲取消息  
  48.         while(true){  
  49.               
  50.             //獲取消息,如果沒有消息,這一步將會一直阻塞  
  51.             Delivery delivery = consumer.nextDelivery() ;  
  52.               
  53.             String msg = new String(delivery.getBody()) ;    
  54.               
  55.             System.out.println("received message[" + msg + "] from " + exchangeName);  
  56.         }  
  57.           
  58.     }  
  59.       
  60. }  


這時,啓動Recv05_01.java 然後啓動Sender05.java ,消費者端就會收到消息。

然後將Sender05.java 中的messageType分別改爲type02  type03 然後發送消息 , 可以看到消費者端能接收到type02的消息,但是不能接收到type03的消息。

轉載:http://blog.csdn.net/is_zhoufeng/article/details/10053057

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章