带有 Spring Boot 应用程序的 docker secret 在 docker swarm 模式下不起作用 /run/secrets

vir*_*sha 3 orchestration docker spring-boot docker-swarm devops

我正在尝试为 MySQL 容器和 Spring Boot 应用程序设置数据库密码的环境变量,这通常在 docker secrets 中声明。

echo "db_secured_password" | docker secret create secret -
Run Code Online (Sandbox Code Playgroud)

这里是配置文件:

spring boot 应用程序的-> application.yml

db:
  name: my-db
  host: localhost
  port: 3306
  username: root
  password: /run/secrets/db-root-password
spring:
  application:
    name: core-backend
  datasource:
    url: jdbc:mysql://${db.host}:${db.port}/${db.name}
    username: ${db.username}
    password: ${db.password}
Run Code Online (Sandbox Code Playgroud)

用于 docker swarm 模式下的 docker 堆栈 -> docker-compose.yml

version: '3.1'

services: 

  mysql-db:
    container_name: mysql-db
    image: mysql:8.0.12
    deploy:
      restart_policy:
        condition: on-failure
    volumes:
      - ./data/mysql:/var/lib/mysql
      - ./conf/mysql/my.cnf:/etc/mysql/conf.d/my.cnf
    environment:
      - MYSQL_ROOT_PASSWORD=/run/secrets/db-root-password
      - MYSQL_DATABASE=my_db
    ports: 
      - "3306:3306"
    secrets: 
      - db-root-password

  spring-boot-app:
    container_name: spring-boot-app
    image: spring-boot-app:local
    environment:
      - DB_PASSWORD=/run/secrets/db-root-password
# Also tried adding with the file as property name
#     - DB_PASSWORD_FILE=/run/secrets/db-root-password
    ports:
      - "8080:8080"
    environment:
      HOST_NAME: localhost
    secrets: 
      - db-root-password
    depends_on:
      - mysql-db

secrets:
  db-root-password:
    external: true
Run Code Online (Sandbox Code Playgroud)

我使用以下命令运行 docker 堆栈:

docker stack deploy --with-auth-registry -c docker-compose.yml test-stack 
Run Code Online (Sandbox Code Playgroud)

我无法db-root-password在 Spring Boot 应用程序中准确获取该属性的值。当我检查 的值时,db-root-password我得到的值为/run/secrets/db-root-password

有什么遗漏吗?如果我想以不同的方式覆盖环境变量的值?

小智 7

我们通过使用“printf”而不是“echo”解决了同样的问题,echo 的问题是它会在 docker secret 中留下一个换行符。您可以参考 docker secret create => https://docs.docker.com/engine/reference/commandline/secret_create/ 中的示例

另外我有一个示例将 docker 机密直接加载到 spring 属性中,例如“spring.datasource.password”=> https://github.com/kwonghung-YIP/spring-boot-docker-secret