Я пытаюсь установить переменные окружения для пароля БД для контейнера MySQL и приложения весенней загрузки, которое обычно объявляется в секретах докера.
echo "db_secured_password" | docker secret create secret -
вот файлы конфигурации:
пружинные загрузочные приложения -> 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}
используется для стека докеров в режиме Docker Swarm -> 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
Я запускаю стек Docker с помощью следующей команды:
docker stack deploy --with-auth-registry -c docker-compose.yml test-stack
Я не могу получить значение свойства db-root-password
точно в приложении весенней загрузки.Когда я проверяю значение db-root-password
, я получаю значение /run/secrets/db-root-password
.
Чего-то не хватает?Если я хочу переопределить значение переменной Environment по-другому?