新建项目:myrabbitmq
- pom
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.blj</groupId>
<artifactId>myrabbitmq</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>amqp-client</artifactId>
<version>4.0.2</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.10</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
</dependency>
</dependencies>
</project>
1.简单队列
- 1.1模型
P:消息的生产者。
红色的:队列。
C:消费者。
3个对象:生产者 队列 消费者。
- 1.2.获取MQ连接。
package com.blj.rabbitmq.util;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import java.io.IOException;
import java.util.concurrent.TimeoutException;
public class ConnectionUtils {
/**
* 获取MQ链接
*
* @return
*/
public static Connection getConnetion() throws IOException, TimeoutException {
ConnectionFactory factory = new ConnectionFactory();
//设置服务地址
factory.setHost("127.0.0.1");
//设置端口号 AMQP 5672
factory.setPort(5672);
//VirtualHost
factory.setVirtualHost("/test");
//用户名
factory.setUsername("root");
//密码
factory.setPassword("root1234");
return factory.newConnection();
}
}
- 1.3生产者生产消息
package com.blj.rabbitmq.simple;
import com.blj.rabbitmq.util.ConnectionUtils;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import java.io.IOException;
import java.util.concurrent.TimeoutException;
public class Send {
public static final String QUEUE_NAME="test_simple_queue";
public static void main(String[] args) throws IOException, TimeoutException {
//获取一个链接
Connection connetion = ConnectionUtils.getConnetion();
//从链接中获取一个通道
Channel channel = connetion.createChannel();
//创建队列声明
channel.queueDeclare(QUEUE_NAME,false,false,false,null);
String msg="hello simple!";
channel.basicPublish("",QUEUE_NAME,null,msg.getBytes());
System.out.println("-- send msg"+msg);
channel.close();
connetion.close();
}
}
- 1.4消费者接受消息
package com.blj.rabbitmq.simple;
import com.blj.rabbitmq.util.ConnectionUtils;
import com.rabbitmq.client.*;
import java.io.IOException;
import java.util.concurrent.TimeoutException;
/**
* 消费者
*
* @author BaiLiJun on 2019/10/24 0024
*/
public class Recv {
public static final String QUEUE_NAME = "test_simple_queue";
public static void main(String[] args) throws Exception {
//获取链接
Connection connetion = ConnectionUtils.getConnetion();
//创建频道
Channel channel = connetion.createChannel();
//创建队列声明
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
//定义消费者
DefaultConsumer consumer = new DefaultConsumer(channel) {
//获取到达消息
@Override
public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
String msg = new String(body, "utf-8");
System.out.println("new api recv msg = " + msg);
}
};
//监听队列
channel.basicConsume(QUEUE_NAME, true, consumer);
}
private static void oldApi() throws IOException, TimeoutException, InterruptedException {
//获取链接
Connection connetion = ConnectionUtils.getConnetion();
//创建频道
Channel channel = connetion.createChannel();
//定义队列消费者
QueueingConsumer consumer = new QueueingConsumer(channel);
//监听队列
channel.basicConsume(QUEUE_NAME, true, consumer);
while (true) {
QueueingConsumer.Delivery delivery = consumer.nextDelivery();
String msg = new String(delivery.getBody());
System.out.println("old api Recv msg = " + msg);
}
}
}
- 1.5简单队列的不足
耦合性高,生产者一一对应消费者(如果我想有多个消费者消费队列中消息,这时候就不行了)队列名变更这时候得同时变更