• RabbitMQ消费端自定义监听(九)


      场景

        我们一般在代码中编写while循环,进行consumer.nextDelivery方法进行获取下一条消息,然后进行消费处理。

      实际环境

        我们使用自定义的Consumer更加的方便,解耦性更强,也在实际工作中最常用。

      操作  

            //生产端代码
            ConnectionFactory connectionFactory = new ConnectionFactory();
            connectionFactory.setHost("127.0.0.1");
            connectionFactory.setPort(5672);
            connectionFactory.setVirtualHost("/");
            
            Connection connection = connectionFactory.newConnection();
            Channel channel = connection.createChannel();
            
            String exchange = "test_consumer_exchange";
            String routingKey = "consumer.save";
            
            String msg = "Hello RabbitMQ Consumer Message";
            
            for(int i =0; i<5; i ++){
                channel.basicPublish(exchange, routingKey, true, null, msg.getBytes());
            }
            //消费端代码
            ConnectionFactory connectionFactory = new ConnectionFactory();
            connectionFactory.setHost("127.0.0.1");
            connectionFactory.setPort(5672);
            connectionFactory.setVirtualHost("/");
            
            Connection connection = connectionFactory.newConnection();
            Channel channel = connection.createChannel();
            
            
            String exchangeName = "test_consumer_exchange";
            String routingKey = "consumer.#";
            String queueName = "test_consumer_queue";
            
            channel.exchangeDeclare(exchangeName, "topic", true, false, null);
            channel.queueDeclare(queueName, true, false, false, null);
            channel.queueBind(queueName, exchangeName, routingKey);
            //使用自定义consumer
            channel.basicConsume(queueName, true, new MyConsumer(channel));    
           //自定义消费端
            //继承DefaultConsumer类
            public class MyConsumer extends DefaultConsumer {
    
    
                   public MyConsumer(Channel channel) {
                           super(channel);
                   }
        
                   //重写handleDelivery()
                  @Override
                  public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                          System.err.println("-----------consume message----------");
                          System.err.println("consumerTag: " + consumerTag);
                          System.err.println("envelope: " + envelope);
                          System.err.println("properties: " + properties);
                          System.err.println("body: " + new String(body));
                   }
    
      
              }    

        运行结果:

        

  • 相关阅读:
    对Postmaster 对 SIGQUIT 信号处理的理解
    kill bgwriter 的小实验
    我对 execl 的学习
    pid_t 数据类型
    我对bgwriter.c 与 guc 关系的初步理解
    对Linux 下 SIGUSR1 与 SIGUSR2 的理解
    向bgwriter 发送 SIGQUIT 的实验
    常用txt图标符号
    也做网页图标favicon.ico
    TakeColor颜色拾取工具
  • 原文地址:https://www.cnblogs.com/luhan777/p/11193004.html
Copyright © 2020-2023  润新知