我在使用 docker-machine 创建的远程主机上尝试使用 docker 机密时遇到问题。
下面是我的 docker-compose.yml:
version: "3.5"
services:
mysql:
image: mysql:5.7
container_name: mysql
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD_FILE: /run/secrets/db_root_password
secrets:
- db_root_password
secrets:
db_root_password:
file: ./db_root_password.txt
这在本地运行良好,我可以运行 docker-compose up 并访问 mysql 容器。
docker-compose up
根密码已经很好地应用了。
我现在正在尝试在使用 docker-machine 创建的远程主机上运行容器。
我首先使用 docker-machine create 创建了机器(在这种情况下,在 exoscale 云上)
docker-machine create --driver exoscale ... MyMachine
然后我尝试使用以下方法部署主机:
eval $(docker-machine env MyMachine)
docker-compose up
但是,当我尝试在远程主机上运行时,出现以下错误:
ERROR: for mysql Cannot create container for service mysql: invalid mount config for type "bind": bind source path does not exist: /Users/user/path/to/db_root_password.txt
所以它仍在尝试用我本地机器上本地文件的路径加载秘密。我怎样才能在远程主机上使用这个秘密?
在此先感谢您的帮助