Docker容器 - 向其注入敏感数据的最佳做法是什么

问题描述 投票:1回答:1

我有一个发送电子邮件的服务。我宁愿不将Gmail密码保存在任何文件中。在谷歌搜索后,我发现我可以在构建它们时使用--build-arg param为容器提供环境变量。

Dockerfile文件

FROM node:latest
ARG buildtime_variable=default_value
ENV env_var_name=$buildtime_variable
...
CMD [ "node", "dist/server.js" ]

构建命令

$ docker build --build-arg buildtime_variable=new_value .

在运行容器中列出环境变量

$ docker exec app env
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=38dd21dbeda3
NODE_VERSION=11.10.0
YARN_VERSION=1.13.0
env_var_name=default_value
HOME=/root

为什么结果env_var_name仍然等于default_value或者我如何将new_value注入容器?

非常感谢每个答案!

docker environment-variables docker-container docker-build docker-exec
1个回答
1
投票

只需使用docker-compose而不是docker命令:

docker-compose build --build-arg buildtime_variable=new_value <container name>

请享用!

© www.soinside.com 2019 - 2024. All rights reserved.