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. python-flask-1

    https://askubuntu.com/questions/244641/how-to-set-up-and-use-a-virtual-python-environment-in-ubuntu ...

  2. Python实现8中常用排序算法

    L = [2,6,4,7,9,1,3,5,8] # 1.插入排序 def insert_sort(List): n = len(List) for i in range(1,n): # 得到索引 j ...

  3. flask-sqlalchemy 配置 mysql (转载的文章)

    一.当然是把必备的包给安装上才行: Flask-SQLAlchemy pip install flask-sqlalchemy MySQL windows下64位压缩包的安装方式可以参考: http: ...

  4. 关于Java中返回零长度数组或空集合比较好,还是返回null这个问题的一些想法

    近日在方法返回类型为List数据类型时,返回结果为空集合比较好,还是null比较好的问题上有点纠结. 我觉得应该统一返回空集合,这样可以不用进行空指针的判断,不然又多了一个产生bug的可能性.而有人认 ...

  5. Java Web学习总结(22)——使用kaptcha生成验证码

    kaptcha是一个简单好用的验证码生成工具,通过配置,可以自己定义验证码大小.颜色.显示的字符等等.下面就来讲一下如何使用kaptcha生成验证码以及在服务器端取出验证码进行校验. 一.搭建测试环境 ...

  6. 如何用PYTHON的CGIHTTPSERVER模块模拟POST请求?

    这次又要逼真一点点,可以弄POST请求啦. 在WEB根目录下新建cgi-bin目录(据说是规模要求),然后运行命令: python -m CGIHTTPServer CGI-BIN目录下,form.p ...

  7. Spring注解@Repository、@Service、@Controller、@Component

    继前几章所讲解的注解中: http://www.cnblogs.com/EasonJim/p/6892280.html http://www.cnblogs.com/EasonJim/p/689974 ...

  8. 利用runtime动态生成对象?

    利用runtime我们能够动态生成对象.属性.方法这特性 假定我们要动态生成DYViewController,并为它创建属性propertyName 1)对象名 NSString *class = @ ...

  9. APP漏洞自动化扫描专业评测报告(中篇)

    前言 上一篇中通过对阿里聚安全[1].360App漏洞扫描[2].腾讯金刚审计系统[3].百度移动云测试中心[4]以及AppRisk Scanner[5] 在收费情况.样本测试后的扫描时间对比和漏洞项 ...

  10. PHP自己定义函数及数组

    个人原创博客:http://www.phpthinking.com/archives/350 一.自己定义函数 自己定义函数就是我们自己定义的函数.在PHP中自己定义函数格式例如以下: 1 funct ...