http://blog.csdn.net/zhu_tianwei/article/details/40887755

参考:http://blog.csdn.NET/lmj623565791/article/details/37669573

使用direct类型实现:消息会被推送至绑定键(binding key)和消息发布附带的选择键(routing key)完全匹配的队列。例如:将不同的日志发送到不同的消费端。

1.发送日志端SendLogDirect.Java

  1. package cn.slimsmart.rabbitmq.demo.route;
  2. import java.util.Random;
  3. import java.util.UUID;
  4. import com.rabbitmq.client.AMQP;
  5. import com.rabbitmq.client.Channel;
  6. import com.rabbitmq.client.Connection;
  7. import com.rabbitmq.client.ConnectionFactory;
  8. //随机发送6条随机类型(routing key)的日志给转发器~~
  9. public class SendLogDirect {
  10. //交换名称
  11. private static final String EXCHANGE_NAME = "ex_logs_direct";
  12. //日志分类
  13. private static final String[] SEVERITIES = { "info", "warning", "error" };
  14. public static void main(String[] args) throws Exception {
  15. //创建连接和频道
  16. ConnectionFactory factory = new ConnectionFactory();
  17. factory.setHost("192.168.101.174");
  18. // 指定用户 密码
  19. factory.setUsername("admin");
  20. factory.setPassword("admin");
  21. // 指定端口
  22. factory.setPort(AMQP.PROTOCOL.PORT);
  23. Connection connection = factory.newConnection();
  24. Channel channel = connection.createChannel();
  25. // 声明转发器的类型
  26. channel.exchangeDeclare(EXCHANGE_NAME, "direct");
  27. //发送6条消息
  28. for (int i = 0; i < 6; i++)
  29. {
  30. String severity = getSeverity();
  31. String message = severity + "_log :" + UUID.randomUUID().toString();
  32. // 发布消息至转发器,指定routingkey
  33. channel.basicPublish(EXCHANGE_NAME, severity, null, message  .getBytes());
  34. System.out.println(" [x] Sent '" + message + "'");
  35. }
  36. channel.close();
  37. connection.close();
  38. }
  39. /**
  40. * 随机产生一种日志类型
  41. *
  42. * @return
  43. */
  44. private static String getSeverity()
  45. {
  46. Random random = new Random();
  47. int ranVal = random.nextInt(3);
  48. return SEVERITIES[ranVal];
  49. }
  50. }

2.接收日志端ReceiveLogsDirect.java

  1. package cn.slimsmart.rabbitmq.demo.route;
  2. import java.util.Random;
  3. import com.rabbitmq.client.AMQP;
  4. import com.rabbitmq.client.Channel;
  5. import com.rabbitmq.client.Connection;
  6. import com.rabbitmq.client.ConnectionFactory;
  7. import com.rabbitmq.client.QueueingConsumer;
  8. //接收端随机设置一个日志严重级别(binding_key)。。。
  9. public class ReceiveLogsDirect {
  10. private static final String EXCHANGE_NAME = "ex_logs_direct";
  11. private static final String[] SEVERITIES = { "info", "warning", "error" };
  12. public static void main(String[] args) throws Exception {
  13. // 创建连接和频道
  14. ConnectionFactory factory = new ConnectionFactory();
  15. factory.setHost("192.168.101.174");
  16. // 指定用户 密码
  17. factory.setUsername("admin");
  18. factory.setPassword("admin");
  19. // 指定端口
  20. factory.setPort(AMQP.PROTOCOL.PORT);
  21. Connection connection = factory.newConnection();
  22. Channel channel = connection.createChannel();
  23. // 声明direct类型转发器
  24. channel.exchangeDeclare(EXCHANGE_NAME, "direct");
  25. String queueName = channel.queueDeclare().getQueue();
  26. String severity = getSeverity();
  27. // 指定binding_key
  28. channel.queueBind(queueName, EXCHANGE_NAME, severity);
  29. System.out.println(" [*] Waiting for "+severity+" logs. To exit press CTRL+C");
  30. QueueingConsumer consumer = new QueueingConsumer(channel);
  31. channel.basicConsume(queueName, true, consumer);
  32. while (true)
  33. {
  34. QueueingConsumer.Delivery delivery = consumer.nextDelivery();
  35. String message = new String(delivery.getBody());
  36. System.out.println(" [x] Received '" + message + "'");
  37. }
  38. }
  39. /**
  40. * 随机产生一种日志类型
  41. *
  42. * @return
  43. */
  44. private static String getSeverity()
  45. {
  46. Random random = new Random();
  47. int ranVal = random.nextInt(3);
  48. return SEVERITIES[ranVal];
  49. }
  50. }

启动几个接收端服务,再启动发送端,接收端对应绑定的键收到对应的消息。

注:发送消息时可以设置routing_key,接收队列与转发器间可以设置binding_key,接收者接收与binding_key与routing_key相同的消息。

(转)RabbitMQ学习之路由(java)的更多相关文章

  1. RabbitMQ学习总结 第五篇:路由Routing

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

  2. (转)RabbitMQ学习之Headers交换类型(java)

    http://blog.csdn.net/zhu_tianwei/article/details/40923131 Headers类型的exchange使用的比较少,它也是忽略routingKey的一 ...

  3. (转) RabbitMQ学习之发布/订阅(java)

    http://blog.csdn.net/zhu_tianwei/article/details/40887733 参考:http://blog.csdn.NET/lmj623565791/artic ...

  4. (转) RabbitMQ学习之远程过程调用(RPC)(java)

    http://blog.csdn.net/zhu_tianwei/article/details/40887885 在一般使用RabbitMQ做RPC很容易.客户端发送一个请求消息然后服务器回复一个响 ...

  5. (转)RabbitMQ学习之主题topic(java)

    http://blog.csdn.net/zhu_tianwei/article/details/40887775 参考:http://blog.csdn.NET/lmj623565791/artic ...

  6. RabbitMQ学习第四记:路由模式(direct)

    1.什么是路由模式(direct) 路由模式是在使用交换机的同时,生产者指定路由发送数据,消费者绑定路由接受数据.与发布/订阅模式不同的是,发布/订阅模式只要是绑定了交换机的队列都会收到生产者向交换机 ...

  7. RabbitMQ学习总结 第三篇:工作队列Work Queue

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

  8. RabbitMQ学习总结 第二篇:快速入门HelloWorld

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

  9. RabbitMQ学习总结 第四篇:发布/订阅 Publish/Subscribe

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

随机推荐

  1. [luogu1129 ZJOI2007] 矩阵游戏 (二分图最大匹配)

    传送门 Description Input Output Sample Input 2 2 0 0 0 1 3 0 0 1 0 1 0 1 0 0 Sample Output No Yes HINT ...

  2. 爬虫数据使用MongDB保存时自动过滤重复数据

    本文转载自以下网站: 爬虫断了?一招搞定 MongoDB 重复数据 https://www.makcyun.top/web_scraping_withpython13.html 需要学习的地方: Mo ...

  3. Python学习笔记之类与对象

    这篇文章介绍有关 Python 类中一些常被大家忽略的知识点,帮助大家更全面的掌握 Python 中类的使用技巧 1.与类和对象相关的内置方法 issubclass(class, classinfo) ...

  4. Hystrix 断流器

    一.分布式系统面临的问题 服务雪崩 多个服务之间调用的时候,假设微服务 A 调用微服务 B 和微服务 C,,微服务 B 和微服务 C 又调用其他的微服务,这就是所谓的“扇出”.如果扇出的链路上某个微服 ...

  5. springMVC知识点复习

    @ResponseBody和@RequestBody的使用 <html> <script type="text/javascript" src="rel ...

  6. (31)Spring Boot导入XML配置【从零开始学Spring Boot】

    [来也匆匆,去也匆匆,在此留下您的脚印吧,转发点赞评论: 您的认可是我最大的动力,感谢您的支持] Spring Boot理念就是零配置编程,但是如果绝对需要使用XML的配置,我们建议您仍旧从一个@Co ...

  7. (13)处理静态资源(自定义资源映射)【从零开始学Spring Boot】

    上面我们介绍了Spring Boot 的默认资源映射,一般够用了,那我们如何自定义目录? 这些资源都是打包在jar包中的,然后实际应用中,我们还有很多资源是在管理系统中动态维护的,并不可能在程序包中, ...

  8. Windows 10不能正常打开开始菜单问题修复

    1.可以尝试通过命令重新注注册Windows Store app: powershell -ExecutionPolicy Unrestricted Add-AppxPackage -DisableD ...

  9. POJ 2914

    无向图全局最小割算法 求 G=(V, E)中任意 s-t 最小割的算法: 定义w(A, x) = ∑w(v[i], x),v[i]  A ∈  定义 Ax 为在x 前加入 A 的所有点的集合(不包括 ...

  10. unity游戏开发之NGUI的UISprite染色

    游戏的UI开发中常常会遇到染色问题.比如button失效变灰的效果,同一个道具通过策划表配的颜色值染上红绿蓝紫等颜色,效果例如以下 最笨最挫的方法当然是让美术多出几个资源图.这种一个缺点是浪费资源,在 ...