RabbitMQ入门学习——Hello World



 

http://www.rabbitmq.com/tutorials/tutorial-one-java.html

 

 

1Introduction

RabbitMQ是一个消息代理。本质上,它从生产者获得消息,然后传递给消费者。在两者之间,根据你给定的规则,它可以路由,缓存或者持久化这些消息。生产者,消费者和代理,它们不需要在同一台机器上。

 

2Hello World

在这部分,我们将写两个java程序;一个生产者发送消息,一个消费者接收消息然后打印他们。我们会轻轻带过一些细节的java api,集中在一些简单的事情上,作为入门学习。

 

3Sending

我们会调用Send发送消息,然后调用Recv接受消息。发送方会连接RabbitMQ,发送一条消息,然后退出。

首先:创建链接serverconnection

ConnectionFactory factory = new ConnectionFactory();

factory.setHost("localhost");

Connection connection = factory.newConnection();

Channel channel = connection.createChannel();

Connection抽象了socket链接,替我们负责一些协议和认证。我们链接的代理在本机,所以使用localhost,如果我们希望连接不同机器的代理,可以使用机器名或ip地址。

 

其次:创建一个channel,大多数API都是通过它来处理一些数据。为了发送消息,我们必须声明一个队列,供我们向其写入消息;然后我们可以向声明的队列中发布消息。

channel.queueDeclare(QUEUE_NAME, false, false, false, null);

String message = "Hello World!";

channel.basicPublish("", QUEUE_NAME, null, message.getBytes());

System.out.println(" [x] Sent '" + message + "'");

 

最后:关闭channelconnection

channel.close();

connection.close();

 

4Receiving

    Receive用来从RabbitMQ推送消息,所以不像发送方,只发布一条消息,Receive需要保持运行状态,用来不断的接受消息然后打印。

    QueueingConsumer类用来缓存服务端推送给我们的消息。Connectionchannel的设置和发送方类似。我们需要打开一个connectionchannel,然后申明一个我们需要获取数据的队列。需要注意的是,此处使用的队列名需要和发送方发布消息时,使用的对列名相匹配。

ConnectionFactory factory = new ConnectionFactory();

factory.setHost("localhost");

Connection connection = factory.newConnection();

Channel channel = connection.createChannel();

 

channel.queueDeclare(QUEUE_NAME, false, false, false, null);

System.out.println(" [*] Waiting for messages. To exit press CTRL+C");

需要注意的是,我们在这里也申明了一个队列。因为我们需要在sender发送方之前启动receiver来监听消息,所以我们必须确保在我们从队列中获取数据时,队列已经存在。

现在我们打算让server从队列中向我们传递消息。由于RabbitMQ是异步向我们推送消息,所以我们需要提供一种回调对象,用来缓存消息,直到我们准备好使用。这就是QueueingConsumer对象需要做的。

QueueingConsumer consumer = new QueueingConsumer(channel);

channel.basicConsume(QUEUE_NAME, true, consumer);

 

while (true) {

      QueueingConsumer.Delivery delivery = consumer.nextDelivery();

      String message = new String(delivery.getBody());

      System.out.println(" [x] Received '" + message + "'");

}

QueueingConsumer.nextDelivery()会发生阻塞,直到另一个消息被server传递。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值