访问交付尝试

要访问阻塞和非阻塞交付尝试,请将这些头添加到您的 @KafkaListener 方法签名中

@Header(KafkaHeaders.DELIVERY_ATTEMPT) int blockingAttempts,
@Header(name = RetryTopicHeaders.DEFAULT_HEADER_ATTEMPTS, required = false) Integer nonBlockingAttempts

仅当您将 ContainerPropertiesdeliveryAttemptHeader 设置为 true 时,才会提供阻塞交付尝试。

请注意,对于初始交付,非阻塞尝试将为 null

从 3.0.10 版本开始,提供了一个方便的 KafkaMessageHeaderAccessor 来简化对这些头的访问;该访问器可以作为监听器方法的参数提供。

@RetryableTopic(backoff = @Backoff(...))
@KafkaListener(id = "dh1", topics = "dh1")
void listen(Thing thing, KafkaMessageHeaderAccessor accessor) {
    ...
}

使用 accessor.getBlockingRetryDeliveryAttempt()accessor.getNonBlockingRetryDeliveryAttempt() 获取值。如果未启用阻塞重试,访问器将抛出 IllegalStateException;对于非阻塞重试,访问器将为初始传递返回 1