其他分享
首页 > 其他分享> > 必备新版RabbitMQ教程-高性能消息队列RabbitMQ课程介绍-小滴课堂

必备新版RabbitMQ教程-高性能消息队列RabbitMQ课程介绍-小滴课堂

作者:互联网

 

 

第八章 玩转RabbitMQ 路由、主题模式实战和总结

第1集 玩转RabbitMQ的路由模式和应用场景

简介:RabbitMQ的路由模式和应用场景

 

第2集 RabbitMQ的路由模式代码实战

简介:RabbitMQ路由模式代码实战

public class Send {    private final static String EXCHANGE_NAME = "exchange_direct";    public static void main(String[] argv) throws Exception {        ConnectionFactory factory = new ConnectionFactory();        factory.setHost("10.211.55.13");        factory.setUsername("admin");        factory.setPassword("password");        factory.setVirtualHost("/xdclass1");        factory.setPort(5672);        /**         * 消息生产者不用过多操作,只需要和交换机绑定即可         */        try (//创建连接             Connection connection = factory.newConnection();             //创建信道             Channel channel = connection.createChannel()) {            //绑定交换机,直连交换机            channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.DIRECT);            String error = "我是错误日志";            String info = "我是info日志";            String debug = "我是debug日志";            channel.basicPublish(EXCHANGE_NAME, "errorRoutingKey", null, error.getBytes(StandardCharsets.UTF_8));            channel.basicPublish(EXCHANGE_NAME, "infoRoutingKey", null, info.getBytes(StandardCharsets.UTF_8));            channel.basicPublish(EXCHANGE_NAME, "debugRoutingKey", null, debug.getBytes(StandardCharsets.UTF_8));            System.out.println("消息发送成功");        }    }}

消息消费者(两个节点)

public class Recv1 {    private final static String EXCHANGE_NAME = "exchange_direct";    public static void main(String[] argv) throws Exception {        ConnectionFactory factory = new ConnectionFactory();        factory.setHost("10.211.55.13");        factory.setUsername("admin");        factory.setPassword("password");        factory.setVirtualHost("/xdclass1");        factory.setPort(5672);        //消费者一般不增加自动关闭        Connection connection = factory.newConnection();        Channel channel = connection.createChannel();        //绑定交换机,fanout扇形,即广播类型        channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.DIRECT);        //获取队列        String queueName = channel.queueDeclare().getQueue();        //绑定队列和交换机,另外一个节点只绑定一个 errorRoutingKey        channel.queueBind(queueName,EXCHANGE_NAME,"errorRoutingKey");    channel.queueBind(queueName,EXCHANGE_NAME,"infoRoutingKey");        channel.queueBind(queueName,EXCHANGE_NAME,"debugRoutingKey");        DeliverCallback deliverCallback = (consumerTag, delivery) -> {            String message = new String(delivery.getBody(), "UTF-8");            System.out.println(" [x] Received '" + message + "'");        };        //自动确认消息        channel.basicConsume(queueName, true, deliverCallback, consumerTag -> { });    }}

 

第3集 玩转RabbitMQ的topic主题通配符模式和应用场景

简介:RabbitMQ的主题模式和应用场景

quick.orange.rabbit 只会匹配  *.orange.* 和 *.*.rabbit ,进到Q1和Q2lazy.orange.elephant 只会匹配 *.orange.* 和 lazy.#,进到Q1和Q2quick.orange.fox 只会匹配 *.orange.*,进入Q1lazy.brown.fox 只会匹配azy.#,进入Q2lazy.pink.rabbit 只会匹配 lazy.#和*.*.rabbit ,同个队列进入Q2(消息只会发一次)quick.brown.fox 没有匹配,默认会被丢弃,可以通过回调监听二次处理lazy.orange.male.rabbit,只会匹配 lazy.#,进入Q2

第4集 玩转RabbitMQ的topic主题通配符模式代码实战

简介:RabbitMQ的topic主题模式代码实战

public class Send {    private final static String EXCHANGE_NAME = "exchange_topic";    public static void main(String[] argv) throws Exception {        ConnectionFactory factory = new ConnectionFactory();        factory.setHost("10.211.55.13");        factory.setUsername("admin");        factory.setPassword("password");        factory.setVirtualHost("/dev");        factory.setPort(5672);        /**         * 消息生产者不用过多操作,只需要和交换机绑定即可         */        try (//创建连接             Connection connection = factory.newConnection();             //创建信道             Channel channel = connection.createChannel()) {            //绑定交换机,直连交换机            channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.TOPIC);            String error = "我是订单错误日志";            String info = "我是订单info日志";            String debug = "我是商品debug日志";            channel.basicPublish(EXCHANGE_NAME, "order.log.error", null, error.getBytes(StandardCharsets.UTF_8));            channel.basicPublish(EXCHANGE_NAME, "order.log.info", null, info.getBytes(StandardCharsets.UTF_8));            channel.basicPublish(EXCHANGE_NAME, "product.log.debug", null, debug.getBytes(StandardCharsets.UTF_8));            System.out.println("消息发送成功");        }    }}

消费者(两个)

public class Recv1 {    private final static String EXCHANGE_NAME = "exchange_topic";    public static void main(String[] argv) throws Exception {        ConnectionFactory factory = new ConnectionFactory();        factory.setHost("10.211.55.13");        factory.setUsername("admin");        factory.setPassword("password");        factory.setVirtualHost("/dev");        factory.setPort(5672);        //消费者一般不增加自动关闭        Connection connection = factory.newConnection();        Channel channel = connection.createChannel();        //绑定交换机        channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.TOPIC);        //获取队列        String queueName = channel.queueDeclare().getQueue();        //绑定队列和交换机,第一个节点        //channel.queueBind(queueName,EXCHANGE_NAME,"order.log.error");   //绑定队列和交换机,第二个节点      //channel.queueBind(queueName,EXCHANGE_NAME,"*.log.*");        DeliverCallback deliverCallback = (consumerTag, delivery) -> {            String message = new String(delivery.getBody(), "UTF-8");            System.out.println(" [x] Received '" + message + "'");        };        //自动确认消息        channel.basicConsume(queueName, true, deliverCallback, consumerTag -> { });    }}

 

第5集 RabbitMQ的多种工作模式总结

简介:RabbitMQ的多个工作模式总结

 

 

标签:教程,String,EXCHANGE,factory,RabbitMQ,交换机,小滴,channel,NAME
来源: https://blog.csdn.net/XDCLASS21/article/details/118086554