美文网首页
Return消息机制

Return消息机制

作者: 快点给我想个名 | 来源:发表于2019-06-30 21:01 被阅读0次
    Return消息机制
    • Return Listener用于处理一些不可路由的消息
    • 我们的消息生产者,通过指定一个Exchange和Routingkey,把消息送达到某一个队列中去,然后我们的消费者监听队列,进行消费处理操作。
    • 某些情况下Exchange不存在或路由key路由不到,这时我们就需要监听这个不可达的消息,就要用return listener


      image.png

      Producer

    public class Producer {
    
        public static void main(String[] args) throws IOException, TimeoutException {
    
            ConnectionFactory factory = new ConnectionFactory();
            factory.setHost("192.168.6.99");
            factory.setPort(5672);
            factory.setVirtualHost("/");
    
            Connection connection = factory.newConnection();
    
            Channel channel = connection.createChannel();
    
            /**
             * mandatory需要设置为true,监听器会接受到路由不可达的消息,然后进行处理
             * 如果为false,则broker端自动删除该消息
             */
            channel.basicPublish("exchange2","return.error",true,null,"hello world".getBytes());
    
            channel.addReturnListener(new ReturnListener() {
                @Override
                public void handleReturn(int replyCode, String replyText, String exchange, String routingKey, AMQP.BasicProperties properties, byte[] body) throws IOException {
                    System.out.println("handleReturn");
                    System.out.println("replyCode "+replyCode);
                    System.out.println("replyText "+replyText);
                    System.out.println("body "+new String(body));
                }
            });
        }
    }
    
    

    Consumer

    public class Consumer1 {
    
        public static void main(String[] args) throws IOException, TimeoutException, InterruptedException {
            ConnectionFactory factory = new ConnectionFactory();
            factory.setHost("192.168.6.99");
            factory.setPort(5672);
            factory.setVirtualHost("/");
    
            Connection connection = factory.newConnection();
    
            Channel channel = connection.createChannel();
    
            channel.exchangeDeclare("exchange2","topic",true);
            channel.queueDeclare("queueName2", true, false, false, null);
    
            channel.queueBind("queueName2","exchange2","return.key");
    
            QueueingConsumer queueingConsumer = new QueueingConsumer(channel);
    
            channel.basicConsume("queueName2",true,queueingConsumer);
    
            while (true){
                QueueingConsumer.Delivery delivery = queueingConsumer.nextDelivery();
                String message = new String(delivery.getBody(), "UTF-8");
                System.out.println(" Received '" + message + "'");
            }
        }
    }
    
    

    相关文章

      网友评论

          本文标题:Return消息机制

          本文链接:https://www.haomeiwen.com/subject/thficctx.html