队列达到最大长度成为死信
在消息队列的声明中设置队列储存的最大消息个数,超过这个个数之后,如果还有消息进来就会变为死信消息放入到相关的死信队列中,大部分代码都是引用的上一章的代码rabbitMq 死信队列(一)消息被拒绝成为死信
消息消费者C1编写
主意如果之前构建过这个普通队列,需要将其删除后再启动C1消费者再进行构建,否则会报错
public class CustomerOne {
/**
* 普通交换机
*/
public static final String NORMAL_EXCHANGE="normal_exchange";
/**
* 死信交换机
*/
public static final String DEAD_EXCHANGE="dead_exchange";
/**
* 普通队列
*/
public static final String NORMAL_QUEUE="normal_queue";
/**
* 死信队列
*/
public static final String DEAD_QUEUE="dead_queue";
public static void main(String[] args) throws Exception{
Channel channel = RabbitMqUtils.getChannel();
// 声明普通交换机
channel.exchangeDeclare(NORMAL_EXCHANGE, BuiltinExchangeType.DIRECT);
// 声明死信交换机
channel.exchangeDeclare(DEAD_EXCHANGE,BuiltinExchangeType.DIRECT);
// 普通队列相关参数
Map<String, Object> arguments=new HashMap<>(16);
// 消息成为死信交换机
arguments.put("x-dead-letter-exchange",DEAD_EXCHANGE);
// 设置死信routingKey
arguments.put("x-dead-letter-routing-key","lisi");
// 设置死信长度
arguments.put("x-max-length",6);
// 声明普通队列
channel.queueDeclare(NORMAL_QUEUE,false,false,false,arguments);
// 绑定普通交换机
channel.queueBind(NORMAL_QUEUE,NORMAL_EXCHANGE,"zhangsan");
// 声明死信队列
channel.queueDeclare(DEAD_QUEUE,false,false,false,null);
// 绑定死信交换机
channel.queueBind(DEAD_QUEUE,DEAD_EXCHANGE,"lisi");
System.out.println("消息的接收.......");
DeliverCallback deliverCallback = (String consumerTag, Delivery message) -> {
String msg = new String(message.getBody());
System.out.println("消息消费: "+msg);
// 手动提交消息消费成功
channel.basicAck(message.getEnvelope().getDeliveryTag(),false);
};
CancelCallback cancelCallback=(consumerTag)->{
System.out.println("消息消费被中断");
};
channel.basicConsume(NORMAL_QUEUE,false,deliverCallback,cancelCallback);
}
}
启动项目
启动C1之后再启动消息生产者,消息生产者一共生产10条消息,有6条成功进入消息队列,其他四条成为死信消息进入死信队列
C1的相关的参数,最大的消息个数为6个
启动消费者之后,普通队列有6条待消费
死信队列有四条待消费