第一步,添加依赖
消费端
<?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.xiaoming</groupId>
<artifactId>springboot-rabbitmq-c</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.8.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
</dependencies>
</project>
服务端
<?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.xiaoming</groupId>
<artifactId>springboot-rabbitmq-p</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.8.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
</dependencies>
</project>
配置文件
消费端
spring:
rabbitmq:
host: 192.168.93.131
port: 5672
virtual-host: /
username: guest
password: guest
listener:
simple:
acknowledge-mode: manual
服务端
spring:
rabbitmq:
host: 192.168.93.131
port: 5672
virtual-host: /
username: guest
password: guest
publisher-confirms: true
publisher-returns: true
代码实现
消费端
package com.xiaoming;
import com.rabbitmq.client.Channel;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
import java.io.IOException;
import java.util.Map;
import java.util.Set;
@Component
public class MyRabbitMQListener {
@RabbitListener(queues = "bootQueue_DXL")
public void testMes(Message message, Channel channel) throws IOException {
long deliveryTag = message.getMessageProperties().getDeliveryTag();
try {
System.out.println(new String(message.getBody()));
channel.basicAck(deliveryTag,false);
} catch (Exception e) {
channel.basicNack(deliveryTag,false,false);
}
}
}
服务端
config
package com.xiaoming.config;
import org.springframework.amqp.core.*;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.HashMap;
import java.util.Map;
@Configuration
public class RabbitMQConfig {
public static final String EXCHANGE_NAME = "topic_Exchange";
public static final String EXCHANGE_NAME_DXL = "topic_Exchange_DXL";
public static final String QUEUE_NAME = "topic_Queue";
public static final String QUEUE_NAME_DXL = "topic_Queue_DXL";
@Bean("bootExchange")
public Exchange getExchange(){
return ExchangeBuilder.topicExchange(EXCHANGE_NAME).durable(true).build();
}
@Bean("bootExchange_DXL")
public Exchange getExchange_DXL(){
return ExchangeBuilder.topicExchange(EXCHANGE_NAME_DXL).durable(true).build();
}
@Bean("bootQueue")
public Queue getQueue(){
Map map = new HashMap();
map.put("x-message-ttl",10000);
map.put("x-max-length",10);
map.put("x-dead-letter-exchange","topic_Exchange_DXL");
map.put("x-dead-letter-routing-key","asdasd.test_DXL");
return QueueBuilder.durable(QUEUE_NAME).withArguments(map).build();
}
@Bean("bootQueue_DXL")
public Queue getQueue_DXL(){
return QueueBuilder.durable(QUEUE_NAME_DXL).withArgument("x-message-ttl",30*60*1000).build();
}
@Bean
public Binding getBinding_DXL(@Qualifier("bootExchange_DXL") Exchange exchange,@Qualifier("bootQueue_DXL") Queue queue){
return BindingBuilder.bind(queue).to(exchange).with("*.test_DXL").noargs();
}
@Bean
public Binding binding(@Qualifier("bootExchange") Exchange exchange,@Qualifier("bootQueue") Queue queue){
return BindingBuilder.bind(queue).to(exchange).with("*.test").noargs();
}
}
消息可靠投递Test
package com.xiaoming.test;
import com.xiaoming.config.RabbitMQConfig;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.connection.CorrelationData;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
public class RabbitMQTest {
@Autowired
private RabbitTemplate rabbitTemplate;
@Test
public void confirmsTest() {
rabbitTemplate.setMandatory(true);
rabbitTemplate.setConfirmCallback(new RabbitTemplate.ConfirmCallback() {
@Override
public void confirm(CorrelationData correlationData, boolean ack, String s) {
if (ack) {
System.out.println("交换机接收到了消息"+s);
} else {
System.out.println("交换机没有接收到消息"+s);
}
}
});
rabbitTemplate.setReturnCallback(new RabbitTemplate.ReturnCallback() {
@Override
public void returnedMessage(Message message, int replyCode, String replyText, String exchange, String routingKey) {
System.out.println("QUEUE没有收到消息,消息返回了");
System.out.println("routingKey为:"+routingKey);
}
});
for (int i = 0; i < 20; i++) {
rabbitTemplate.convertAndSend(RabbitMQConfig.EXCHANGE_NAME, "sdsad.test", "asdasdasd");
}
}
}