用java写一个用到rabbitmq的demo
时间: 2023-07-01 08:05:09 浏览: 118
xmljava系统源码-spring-boot-demo:springbootdemo是一个用来深度学习并实战springboot的项目,该项
好的,以下是一个简单的使用 RabbitMQ 的 Java demo:
首先,需要引入 RabbitMQ 的依赖,可以在 Maven 中添加以下依赖:
```xml
<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>amqp-client</artifactId>
<version>5.7.3</version>
</dependency>
```
然后,创建一个生产者类来发送消息:
```java
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
public class Producer {
private final static String QUEUE_NAME = "hello";
public static void main(String[] args) throws Exception {
// 创建连接工厂
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
// 建立连接
Connection connection = factory.newConnection();
// 创建通道
Channel channel = connection.createChannel();
// 声明队列
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
// 发送消息
String message = "Hello, RabbitMQ!";
channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));
System.out.println("Sent message: " + message);
// 关闭通道和连接
channel.close();
connection.close();
}
}
```
在上面的示例中,我们创建了一个连接工厂,然后使用它创建了一个连接。接着,我们创建了一个通道,并声明了一个队列。最后,我们发送了一条消息,并关闭了通道和连接。
接下来,创建一个消费者类来接收消息:
```java
import com.rabbitmq.client.*;
import java.io.IOException;
public class Consumer {
private final static String QUEUE_NAME = "hello";
public static void main(String[] args) throws Exception {
// 创建连接工厂
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...");
// 创建消费者
DefaultConsumer 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("Received message: " + message);
}
};
// 开始消费
channel.basicConsume(QUEUE_NAME, true, consumer);
}
}
```
在上面的示例中,我们创建了一个连接工厂,然后使用它创建了一个连接。接着,我们创建了一个通道,并声明了一个队列。然后,我们创建了一个消费者,并在 `handleDelivery` 方法中处理接收到的消息。最后,我们调用 `basicConsume` 方法开始消费消息。
现在,我们可以运行生产者和消费者来测试 RabbitMQ 是否正常工作。首先运行生产者,然后运行消费者,就可以看到消息被正确发送和接收了。
阅读全文