簡體   English   中英

如何遷移到函數式編程模型以在 Spring Cloud 中發布到 Kafka

[英]How to move to functional programming model to publish to Kafka in Spring cloud

我正在嘗試擺脫現在已棄用的注釋,例如 @EnableBinding 和 @Output,但找不到一個簡單的示例來以功能方式執行此操作。 這些是當前的文件:

KafkaConfig.java

@Configuration
@EnableBinding({
        CcRegistrationFailureChannel.class
})
public class KafkaConfig {
}

CcRegistrationFailureChannel.java

public interface CcRegistrationFailureChannel {
    String CC_REGISTRATION = "cc-registration";

    @Output(CC_REGISTRATION)
    MessageChannel ccFailureChannel();
}

CcRegistrationFailurePublisher.java

@Log4j2
@Component
public class CcRegistrationFailurePublisher {
    public void publish(MessageChannel outputChannel, EventPayload payLoad) {
        boolean success = outputChannel.send(MessageBuilder
                .withPayload(payLoad)
                .setHeader(MessageHeaders.CONTENT_TYPE, MimeTypeUtils.APPLICATION_JSON)
                .build()
        );
        if (!success) {
            log.error("CC Registration Failure: publish message failed");
        }
    }
}

從以下代碼調用消息發布:

@Autowired
private final CcRegistrationFailurePublisher ccRegistrationFailurePublisher;

public void sendCCRegistrationFailure(String internalUserId) {
    Long unixEpochTime = Instant.now().getEpochSecond();
    CcRegistrationFailureEventPayload ccRegistrationFailureEventPayload =
            new CcRegistrationFailureEventPayload(internalUserId, unixEpochTime, CcFailureEventType.ADD_CC_FAILURE);
    ccRegistrationFailurePublisher.publish(ccRegistrationFailureChannel.ccFailureChannel(), ccRegistrationFailureEventPayload);
}

如何從當前狀態遷移到使用 Spring 推薦的功能方式?

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM