我这里有一个“无聊”的问题。让我解释...

我正在尝试从我的docker-compose的Application.properties中读取一些“环境变量”。

虽然,我在容器中正确地创建了env的变量(我在检查容器时可以看到),但是它们并没有从Spring Boot应用程序中读取。

这些“码头工人组成的环境变量”有点像“不可访问”。

我正在做测试;因此,我是Spring应用程序中的一个环境变量,它是'null',例如:

@Slf4j
@SpringBootApplication(exclude = R2dbcAutoConfiguration.class)
public class AppDriver {
    public static void main(String[] args) {
        
        System.out.println("container variables >>>>> " + System.getenv("MASTER_URL"));

        SpringApplication.run(AppDriver.class,args);
    }

日志是:

容器变量>>>>> null

在下面,它们是我的docker-compose:

version: "3.5"

services:

  tenant1:
    image: postgres
    ports:
      - "5432:5432"
    restart: always
    environment:
      POSTGRES_PASSWORD: password
      POSTGRES_DB: tenant1
      POSTGRES_USER: user
    volumes:
      - ./data/tenant1:/var/lib/postgresql

  mysql:
    image: mysql:5.7
    ports:
      - "3306:3306"
    environment:
      MASTER_URL: r2dbc:mysql://user:password@localhost/master
      MYSQL_ROOT_PASSWORD: mysecret
      MYSQL_USER: user
      MYSQL_PASSWORD: password
      MYSQL_DATABASE: master

我的Application.properties:

logging.level.com.example=DEBUG
logging.level.io.r2dbc=DEBUG

master.url = ${MASTER_URL}

最后,我的Java文件:

@Configuration
//@ConfigurationProperties(prefix = "master")
@EnableR2dbcRepositories(entityOperationsRef = "masterEntityTemplate")
public class MasterConfig {

    @Value("${master.url}")
    private String url;

    @Bean
    @Qualifier(value = "masterConnectionFactory")
    public ConnectionFactory masterConnectionFactory() {

        System.out.println(">>>>>>>>>>>" + url);

        return ConnectionFactories.get(url);
        //.get("r2dbc:mysql://user:password@localhost/master");
    }

那就是我正在犯的最后一个错误:

原因:java.lang.IllegalArgumentException:无法解析值“ $ {MASTER_URL}”中的占位符“ MASTER_URL”

有人知道如何解决这个问题吗?

非常感谢