RabbitMQ优化配置小记

消息确认机制:

@Bean
    @Scope("prototype")
    public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
        RabbitTemplate template = new RabbitTemplate(connectionFactory);
        template.setMandatory(true);
        template.setMessageConverter(new Jackson2JsonMessageConverter());
        return template;
    }

使用该代码是因为每一个方法消息确认都不一样,这样配置可以让消息生产送达确认的时候,进行个性化的操作

线程池配置:

   @Bean
    public RabbitListenerContainerFactory<?> rabbitListenerContainerFactory(ConnectionFactory connectionFactory) {
        SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        factory.setConcurrentConsumers(1);
        factory.setMaxConcurrentConsumers(10);
        factory.setMessageConverter(new Jackson2JsonMessageConverter());
        factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);
        return factory;
    }

该配置中
factory.setConcurrentConsumers(1);为初始化连接池最小连接数(常驻链接)
factory.setMaxConcurrentConsumers(10);为最大连接池数量
factory.setMessageConverter(new Jackson2JsonMessageConverter());为序列化方式
factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);确认方式,manual为手动ack.

注意,该配置为全局配置,会导致所有的消费者全部使用该配置信息.设置过大or过小很可能都无法满足需求
例如某消费者,需要100个线程,另外一个消费者只需要一个线程慢慢消费的场景

正确配置:

   @Bean
    public RabbitListenerContainerFactory<?> rabbitListenerContainerFactory(ConnectionFactory connectionFactory) {
        SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        factory.setMessageConverter(new Jackson2JsonMessageConverter());
        factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);
        return factory;
    }

删除掉

factory.setConcurrentConsumers(1);
factory.setMaxConcurrentConsumers(10);

在注解RabbitListener中增加concurrency来进行配套使用.1-3为最小连接数为1 最大为3

@RabbitListener(queues = 队列名称, concurrency = "1-3")

消息确认:

channel.basicAck(msg.getMessageProperties().getDeliveryTag(), false); // 确认该条消息
channel.basicNack(msg.getMessageProperties().getDeliveryTag(), false, true); // 该条消息回弹到队列头的部分马上开始重新消费.

可以通过绑定多个交换机的形式,来对他进行达到一定次数后发送到其他的队列中进行处理.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值