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. nyoj29-求置转换问题

    求转置矩阵问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:2 描述 求一个三行三列的转置矩阵. 输入 第一行一个整数n<20,表示有n组测试数据,下面是n组数据;每组测 ...

  2. phpcms_完整版

    {pc:content action="category" catid="0" num="6" siteid="$siteid&q ...

  3. win7 VMware下安装centos和Ubuntu共存

      最近在空闲时间学习Linux环境中各种服务的安装与配置,都属于入门级别的,这里把所有的学习过程记录下来,和大家一起分享. 我的电脑系统是win7,所以我需要在win7上安装一个虚拟机-VMware ...

  4. form提交表单中包含time类型数据

    当数据库和实体类中含有date类型的数据时 ,form提交的时间数据只是string类型的,所以不能直接写入到java实体类和数据库,经过百度找到了解决方法 ,特地挪过来: 在controller中增 ...

  5. 【codeforces 793A】Oleg and shares

    [题目链接]:http://codeforces.com/contest/793/problem/A [题意] 每次你可以对1..n中的任意一个数字进行减少k操作; 问你最后可不可能所有的数字都变成一 ...

  6. VirtualBox虚拟机下 解决centos系统无法上网的问题

    首先,在VirtualBox中设置网卡连接方式:点“设置”,在弹出的界面中点“网络”,最后选择“连接方式”为“桥接网卡”或者网都可以络地址转换  这两种我试了试都可以 接下来修改一个文件就行: 1.打 ...

  7. 2017年JavaScript框架---Top5

    前言 个人观点,供您参考 观点源自作者的使用经验和日常研究 排名基于框架的受欢迎度, 语法结构, 易用性等特性 希望大家能够基于此视频找到最适合自己的框架 下面介绍的都是严格的前端框架和库 前言 To ...

  8. [bzoj4084][Sdoi2015]双旋转字符串_hash

    双旋转字符串 bzoj-4084 Sdoi-2015 题目大意:给定两个字符串集合 S 和 T .其中 S 中的所有字符串长度都恰好为 N ,而 T 中所有字符串长度都恰好为 M .且 N+M 恰好为 ...

  9. Javascript中的原型继承具体解释

    js中的继承,是面向对象的知识,由于js没有类的概念.所以继承是通过对象实现的.谈到继承.就必须说到prototype,就不得不先说下new的过程. 一个小小的列子: <script type= ...

  10. 先序遍历创建二叉树,对二叉树统计叶子节点个数和统计深度(创建二叉树时#代表空树,序列不能有误)c语言

    #include "stdio.h" #include "string.h" #include "malloc.h" #define NUL ...