Rabbitmq

docker run -d --name rabbitmq -p 15672:15672 -p 5672:5672 -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -v C:/data/rabbitmq:/var/lib/rabbitmq rabbitmq:3-management

15672 JMS 链接端口

5672 AMQP 多平台链接端口

消费者

复制代码
@Component
@RabbitListener(queues = "message_queue") //队列名
public class MessageMQListener {

    @RabbitHandler
    public void messageHandler(String body, Message message, Channel channel) throws IOException {

        long msgTag = message.getMessageProperties().getDeliveryTag();
        System.out.println("msgTag="+msgTag);
        System.out.println("message="+message);
        System.out.println("body="+body);
        //手动ack确认 msgTag 信息   false 表示仅确认当前这条消息
        channel.basicAck(msgTag,false);
        // 手动拒绝确认       msgTag 信息   false 表示仅确认当前这条消息     true是否重新投递
//        channel.basicNack(msgTag,false,true);
    }
}

生产者

复制代码
@Configurable
public class RabbitMqConfig {

    public static final String EXCHANGE_NAME = "message_exchange";

    public static final String QUEUE = "message_queue";


    /**
     * topic 交换机
     * @return
     */
    @Bean
    public Exchange messageExchange(){
        return ExchangeBuilder.topicExchange(EXCHANGE_NAME).durable(true).build();
    }

    /**
     * 队列
     * @return
     */
    @Bean
    public Queue messageQueue(){
        return QueueBuilder.durable(QUEUE).build();
    }

    /**
     * 交换机和队列绑定关系
     */
    @Bean
    public Binding messageBinding(Queue queue, Exchange exchange){
        return BindingBuilder.bind(queue).to(exchange).with("message.#").noargs();
    }


}

------------------------------------------------------------------------------------------
	@Autowired
	private RabbitTemplate rabbitTemplate;
	void testSend(){
		rabbitTemplate.convertAndSend(RabbitMqConfig.EXCHANGE_NAME,"message.XX","新消息");
	}
	
	@Test
	void testConfirmCallback(){
		rabbitTemplate.setConfirmCallback(new RabbitTemplate.ConfirmCallback() {
			@Override
			public void confirm(CorrelationData correlationData, boolean ack, String cause) {

				System.out.println("ConfirmCallback--------");
				System.out.println("ConfirmCallback--------"+correlationData);
				System.out.println("ConfirmCallback--------"+ack);
				System.out.println("ConfirmCallback--------"+cause);
				if(ack){
					System.out.println("发送成功");
				}else{
					System.out.println("发送失败");
				}
			}
		});
		rabbitTemplate.convertAndSend(RabbitMqConfig.EXCHANGE_NAME,"message.xx","新消息");

	}
	@Test
	void testReturnCallback(){
		rabbitTemplate.setReturnsCallback(new RabbitTemplate.ReturnsCallback() {
			@Override
			public void returnedMessage(ReturnedMessage returnedMessage) {
				int code = returnedMessage.getReplyCode();
				System.out.println("code = " +code);
				System.out.println("returnedMessage = "+returnedMessage );

			}
		});
		//		rabbitTemplate.convertAndSend(RabbitMqConfig.EXCHANGE_NAME,"x.message.XXX,"新消息");//失败
		rabbitTemplate.convertAndSend(RabbitMqConfig.EXCHANGE_NAME,"message.XXX","新消息");//成功
	}

消息有哪几种情况成为死信

消费者拒收消息(basic.reject/ basic.nack),并且没有重新入队 requeue=false

消息在队列中未被消费,且超过队列或者消息本身的过期时间TTL(time-to-live)

队列的消息长度达到极限

结果:消息成为死信后,如果该队列绑定了死信交换机,则消息会被死信交换机重新路由到死信队列

相关推荐
遇见火星6 小时前
Docker Compose 完全入门:一键启动所有容器
运维·docker·容器·docker compose
云原生指北10 小时前
Apple Container Machine:把 Linux 搬进 Mac
macos·docker
linux修理工13 小时前
使用codebuddy学习kafka
分布式·学习·kafka
阿 才13 小时前
跟文件系统(busybox)的构建
大数据·hadoop·分布式
老纪14 小时前
Redis分布式锁进第九零篇
数据库·redis·分布式
Amy1870211182314 小时前
分布式光伏防孤岛保护:技术逻辑、标准演进与工程实践全解析
分布式
隐层漫游者14 小时前
2026全网最细Docker容器化实战!从安装配置到Milvus向量数据库部署,一文掌握核心精髓(建议收藏)
docker
ACP广源盛1392462567315 小时前
IX7008 PCIe 交换芯片@ACP#RTX Spark 经济型 8 口扩展芯片(对比 ASM1806)
大数据·人工智能·分布式·嵌入式硬件·gpt·spark·电脑
ACP广源盛1392462567315 小时前
IX6012 PCIe 交换芯片@ACP#RTX Spark 入门级 12 口存储外设扩展方案(对比 ASM1812)
大数据·人工智能·分布式·嵌入式硬件·gpt·spark·电脑
加加and减减16 小时前
Docker真实安装mysql8教程并优化配置
运维·mysql·docker·容器