Spring RabbitMQ Transaction

For synchronous use cases with RabbitTemplate,the template has been configured with channelTransacted=true.(channelTransacted是否主动ack)

@Transactional
public void doSomething() {
    String incoming = rabbitTemplate.receiveAndConvert();
    // do some more database processing...
    String outgoing = processInDatabaseAndExtractReply(incoming);
    rabbitTemplate.convertAndSend(outgoing);
}

For asynchronous use cases with SimpleMessageListenerContainer,

@EnableTransactionManagement(proxyTargetClass = true)

@Configuration
public class ExampleExternalTransactionAmqpConfiguration {

    @Bean
    public SimpleMessageListenerContainer messageListenerContainer() {
        SimpleMessageListenerContainer container = new SimpleMessageListenerContainer();
        container.setConnectionFactory(rabbitConnectionFactory());
        container.setTransactionManager(transactionManager());
        container.setChannelTransacted(true);
        container.setQueueName("some.queue");
        container.setMessageListener(exampleListener());
        return container;
    }

}

static class TxServiceImpl implements TxService {

    @Override
    @Transactional
    @RabbitListener(...)
    public String handle(@Payload Foo foo, @Header("amqp_receivedRoutingKey") String rk) {
        ...
    }

}

RabbitMQ的transaction、confirm、ack三个概念的解释
Rabbitmq为什么使用信道channel呢

你可能感兴趣的:(RabbitMQ)