gpt4 book ai didi

java - @ServiceActivator如何在Spring Boot中从属性文件读取inputChannel?

转载 作者:行者123 更新时间:2023-12-02 09:07:53 26 4
gpt4 key购买 nike

我开发了 google pubsub 消费者,当我使用固定值“my-alpha-pubsub-topic”时,它就完成了运行

@ServiceActivator(inputChannel = "my-alpha-pubsub-topic" )
public void messageReceiver(String payload) {
LOGGER.info("Message arrived! Payload: " + payload);

}

但是我在 Kubernetes 中的容器上运行它,我需要通过环境从 env 参数传递 inputChannel 值,以实现 1 个容器构建支持多个环境

Alpha => inputChannel = "my-alpha-pubsub-topic"
Staging => inputChannel = "my-staging-pubsub-topic"
Production => inputChannel = "my-pubsub-topic"

购买时无法在 inputChannel 中传递参数。运行失败

@Value("${pubsub.name}")
private String pubsubName;


@ServiceActivator(inputChannel = "${pubsubName}" )
public void messageReceiver(String payload) {
LOGGER.info("Message arrived! Payload: " + payload);

}

我尝试了这个但失败了

@ServiceActivator(inputChannel = "${pubsubName}" ) 
@ServiceActivator(inputChannel = "#{${pubsubName}}" )
@ServiceActivator(inputChannel = "${pubsub.name}" )

如何从属性或环境参数将值传递给 inputChannel

最佳答案

问题是你不能使用@ServiceActivator(inputChannel = "${pubsub.name}") 因为 inputChannel 需要指定 spring bean 的限定符而不是环境变量。我想您的代码中的某个地方有一个带有限定符 my-alpha-pubsub-topic 的 channel ,这就是它第一次起作用的原因。

就我的观点而言,使用 spring 配置文件创建所有这些 bean 并为每个环境提供类似以下内容会更有意义

 @Profile("Staging") 
@ServiceActivator(inputChannel = "my-staging-pubsub-topic" )
public void messageReceiver(String payload) {
LOGGER.info("Message arrived! Payload: " + payload);
}

关于java - @ServiceActivator如何在Spring Boot中从属性文件读取inputChannel?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59663664/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com