我们使用 (docker-compose) 卷将 Linux 机器中的一个文件夹安装到我们的 docker 容器应用程序中: - /mnt/share:/mnt/share
/mnt/share 是机器中的已安装文件夹(不是机器中的真实文件夹,它是我们的文件服务器)。如果由于某种原因挂载丢失,然后再次重新挂载。在容器重新启动之前,在 docker 容器中运行的应用程序无法访问已安装的文件夹。
我们使用 (docker-compose) 卷将 Linux 机器中的一个文件夹安装到我们的 docker 容器应用程序中: - /mnt/share:/mnt/share
/mnt/share 是机器中的已安装文件夹(不是机器中的真实文件夹,它是我们的文件服务器)。如果由于某种原因挂载丢失,然后再次重新挂载。在容器重新启动之前,在 docker 容器中运行的应用程序无法访问已安装的文件夹。
您可能希望使用卷驱动程序而不是绑定安装本地文件系统。请参阅在机器之间共享数据
如果不进一步了解您的环境,就不可能给出更详细的答案。了解您的容器是在 AWS 数据中心运行还是使用 nfsv3、nfsv4 或 cifs 进行挂载会很有帮助。
以下解决方案帮助我继续。我写了一个脚本来检查文件夹是否存在。然后该脚本在 docker-compose 文件中被称为命令。
version:"3"
services:
flowable-task-handler:
build: flowable-task-handler
ports:
- "8085:8085"
command: bash -c "/wait_for_file_mount.sh /mnt/share/fileshares/ && java -jar /app.jar"
wait_for_file_mount.sh
#!/bin/sh
# Used to check whether the mount folder is ready for flowable to use
mountedfolder="$1"
until [ -d "$mountedfolder" ];
do sleep 2;
echo error "Mounted folder not found : $mountedfolder";
done;
它是一个弹簧启动应用程序。我已删除 DockerFile 中的入口点,并使用 docker compose(java -jar /app.jar") 中的命令启动应用程序
将挂载传播定义为 ":shared" 应该可以解决这个问题:
-v /autofs:/autofs:共享\
不确定 docker-compose - 我并没有真正使用它。但是您可以使用挂载传播定义一个 docker 卷并将其放入您的 DC 文件中。