阅读 262

RabbitMQ—Android客户端

工作原理

RabbitMQ-中文文档 RabbitMQ-官网 上面的网站详细的描述了整个框架。建议没接触过RabbitMQ的同学先看看。了解原理后,就直接看下面的代码吧。

生产者

由于后台缘故,这里不需要exchange。想要看完整的流程的同学可以去看这篇文章。 注意要在子线程中运行

        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost(HOST);//ip地址
        factory.setPort(PORT);//端口号
        factory.setUsername("test");
        factory.setPassword("test");
        //创建一个新连接
        Connection connection = factory.newConnection();
        //创建一个通道
        Channel channel = connection.createChannel();
        //声明一个队列
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        //发送消息
        channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));
        //消息发送完成后,需要关闭通道和连接
        channel.close();
        connection.close();
复制代码

消费者

        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost(HOST);
        factory.setPort(PORT);
        factory.setUsername("test");
        factory.setPassword("test");
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();

        //声明一个队列
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        Consumer consumer = new DefaultConsumer(channel) {
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                String message = new String(body, "UTF-8");
                System.out.println("RecvLogsTopic1 [x] Received '" + envelope.getRoutingKey() + "':'" + message + "'");
            }
        };
        channel.basicConsume(QUEUE_NAME, true, consumer);
复制代码
关注下面的标签,发现更多相似文章
评论