生產者:java
package com.toov5.topic; import java.io.IOException; import java.util.concurrent.TimeoutException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.toov5.utils.MQConnectionUtils; //生產者 交換機類型 producerFanout類型 public class TopicProducer { //交換機名稱 private static final String EXCHANGE_NAME = "my_topic"; public static void main(String[] args) throws IOException, TimeoutException { //創建MQ鏈接 Connection connection = MQConnectionUtils.newConnection(); //建立通道 Channel channel = connection.createChannel(); //生產者綁定交換機 channel.exchangeDeclare(EXCHANGE_NAME, "topic"); //交換機名稱 交換機類型 String routingKey="log.email"; //消息只會給郵件類型的 //建立對應的消息 String msString = "my_Routing_destination_msg"+routingKey; //經過頻道 發送消息 System.out.println("生產者投遞消息:"+msString); channel.basicPublish(EXCHANGE_NAME, routingKey, null, msString.getBytes()); //關閉通道 和 鏈接 channel.close(); connection.close(); } }
消費者:ide
package com.toov5.topic; import java.io.IOException; import java.util.concurrent.TimeoutException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.DefaultConsumer; import com.rabbitmq.client.Envelope; import com.rabbitmq.client.AMQP.BasicProperties; import com.toov5.utils.MQConnectionUtils; //郵件消費者 public class ConsumerSMSTopic { private static final String SMS_QUEUE ="sms_queue_topic"; //交換機名稱 private static final String EXCHANGE_NAME = "my_topic"; public static void main(String[] args) throws IOException, TimeoutException { System.out.println("短信消費者啓動"); //創建MQ鏈接 Connection connection = MQConnectionUtils.newConnection(); //建立通道 Channel channel = connection.createChannel(); //消費者聲明隊列 channel.queueDeclare(SMS_QUEUE, false, false, false, null); //消費者隊列綁定 路由 channel.queueBind(SMS_QUEUE, EXCHANGE_NAME, "log.*"); //消費者監聽消息 DefaultConsumer defaultConsumer = new DefaultConsumer(channel) { //重寫監聽方法 @Override public void handleDelivery(String consumerTag, Envelope envelope, BasicProperties properties, byte[] body) throws IOException { String msg = new String(body,"UTF-8"); System.out.println("短信消費者獲取生產者消息"+msg); } }; channel.basicConsume(SMS_QUEUE,true, defaultConsumer); //綁定隊列 事件監聽 } }
package com.toov5.topic; import java.io.IOException; import java.util.concurrent.TimeoutException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.DefaultConsumer; import com.rabbitmq.client.Envelope; import com.rabbitmq.client.AMQP.BasicProperties; import com.toov5.utils.MQConnectionUtils; //郵件消費者 public class ConsumerEmailTopic { private static final String EMAIL_QUEUE ="email_queue_topic"; //交換機名稱 private static final String EXCHANGE_NAME = "my_topic"; public static void main(String[] args) throws IOException, TimeoutException { System.out.println("郵件消費者啓動"); //創建MQ鏈接 Connection connection = MQConnectionUtils.newConnection(); //建立通道 Channel channel = connection.createChannel(); //消費者聲明隊列 channel.queueDeclare(EMAIL_QUEUE, false, false, false, null); //消費者隊列綁定 路由 channel.queueBind(EMAIL_QUEUE, EXCHANGE_NAME, "log.email"); //消費者監聽消息 DefaultConsumer defaultConsumer = new DefaultConsumer(channel) { //重寫監聽方法 @Override public void handleDelivery(String consumerTag, Envelope envelope, BasicProperties properties, byte[] body) throws IOException { String msg = new String(body,"UTF-8"); System.out.println("郵件消費者獲取生產者消息"+msg); } }; channel.basicConsume(EMAIL_QUEUE,true, defaultConsumer); //綁定隊列 事件監聽 } }
能夠看到兩個消費者均可以接收到spa
生產者:code
package com.toov5.topic; import java.io.IOException; import java.util.concurrent.TimeoutException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.toov5.utils.MQConnectionUtils; //生產者 交換機類型 producerFanout類型 public class TopicProducer { //交換機名稱 private static final String EXCHANGE_NAME = "my_topic"; public static void main(String[] args) throws IOException, TimeoutException { //創建MQ鏈接 Connection connection = MQConnectionUtils.newConnection(); //建立通道 Channel channel = connection.createChannel(); //生產者綁定交換機 channel.exchangeDeclare(EXCHANGE_NAME, "topic"); //交換機名稱 交換機類型 String routingKey="log.email.sms"; //消息只會給郵件類型的 //建立對應的消息 String msString = "my_Routing_destination_msg"+routingKey; //經過頻道 發送消息 System.out.println("生產者投遞消息:"+msString); channel.basicPublish(EXCHANGE_NAME, routingKey, null, msString.getBytes()); //關閉通道 和 鏈接 channel.close(); connection.close(); } }
消費者:blog
package com.toov5.topic; import java.io.IOException; import java.util.concurrent.TimeoutException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.DefaultConsumer; import com.rabbitmq.client.Envelope; import com.rabbitmq.client.AMQP.BasicProperties; import com.toov5.utils.MQConnectionUtils; //郵件消費者 public class ConsumerSMSTopic { private static final String SMS_QUEUE ="sms_queue_topic"; //交換機名稱 private static final String EXCHANGE_NAME = "my_topic"; public static void main(String[] args) throws IOException, TimeoutException { System.out.println("短信消費者啓動"); //創建MQ鏈接 Connection connection = MQConnectionUtils.newConnection(); //建立通道 Channel channel = connection.createChannel(); //消費者聲明隊列 channel.queueDeclare(SMS_QUEUE, false, false, false, null); //消費者隊列綁定 路由 channel.queueBind(SMS_QUEUE, EXCHANGE_NAME, "log.#"); //消費者監聽消息 DefaultConsumer defaultConsumer = new DefaultConsumer(channel) { //重寫監聽方法 @Override public void handleDelivery(String consumerTag, Envelope envelope, BasicProperties properties, byte[] body) throws IOException { String msg = new String(body,"UTF-8"); System.out.println("短信消費者獲取生產者消息"+msg); } }; channel.basicConsume(SMS_QUEUE,true, defaultConsumer); //綁定隊列 事件監聽 } }
package com.toov5.topic; import java.io.IOException; import java.util.concurrent.TimeoutException; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.DefaultConsumer; import com.rabbitmq.client.Envelope; import com.rabbitmq.client.AMQP.BasicProperties; import com.toov5.utils.MQConnectionUtils; //郵件消費者 public class ConsumerEmailTopic { private static final String EMAIL_QUEUE ="email_queue_topic"; //交換機名稱 private static final String EXCHANGE_NAME = "my_topic"; public static void main(String[] args) throws IOException, TimeoutException { System.out.println("郵件消費者啓動"); //創建MQ鏈接 Connection connection = MQConnectionUtils.newConnection(); //建立通道 Channel channel = connection.createChannel(); //消費者聲明隊列 channel.queueDeclare(EMAIL_QUEUE, false, false, false, null); //消費者隊列綁定 路由 channel.queueBind(EMAIL_QUEUE, EXCHANGE_NAME, "log.email"); //消費者監聽消息 DefaultConsumer defaultConsumer = new DefaultConsumer(channel) { //重寫監聽方法 @Override public void handleDelivery(String consumerTag, Envelope envelope, BasicProperties properties, byte[] body) throws IOException { String msg = new String(body,"UTF-8"); System.out.println("郵件消費者獲取生產者消息"+msg); } }; channel.basicConsume(EMAIL_QUEUE,true, defaultConsumer); //綁定隊列 事件監聽 } }