将Docker容器还原到另一个Docker主机时失败

时间:2020-02-13 08:26:44

标签: docker

我使用以下方法创建了容器的tar文件。

在第一个或源Docker主机上:

docker commit -p  78727078a04b  jenkins
docker save -o ~/jenkins.tar jenkins

然后在新的Docker主机(这是另一台机器)上

docker load -i ~/jenkins.tar
docker run -p 8080:8080 -p 50000:50000 jenkins

但是,我遇到了这个错误

docker: Error response from daemon: cannot mount volume over existing file, file exists /var/lib/docker/overlay2/e668ec2b2a563f692e4511352a0db2989791281cc8d13f04f36f02106ceebb0c/merged/run/docker.sock.

2 个答案:

答案 0 :(得分:3)

通常的做法是不要尝试“移动”或“保存”或“导出”或“提交”容器。只需在新机器上创建一个新容器即可。

为此,您需要将容器所需的所有关键数据存储在容器外部。 Jenkins image documentation对此进行了讨论。它强烈建议使用命名卷,因为命名卷很难通过几种方式进行管理。 Docker documentation on backing up named volumes与此相关。

我假设您已经创建了一个命名卷来保存内容。如果没有,请the Jenkins Dockerfile declares a VOLUME,因此应该有一个存放Jenkins主目录的匿名卷。我会使用docker volume lsdocker inspect查找其卷ID,然后尝试使用它。

# when you initially started Jenkins; copied from
# https://github.com/jenkinsci/docker/blob/master/README.md
docker run \
  -p 8080:8080 -p 50000:50000 \
  -v jenkins_home:/var/jenkins_home \
  jenkins/jenkins:lts

您需要从卷中导出数据。 (docker stop詹金斯可能首先是个好主意。)您可以使用一个临时容器来执行此操作:

docker run \
  --rm \
  -v jenkins_home:/jenkins_home \
  -v $PWD:/export \
  -w /jenkins_home \
  busybox \
  tar cf /export/jenkins_home.tar .
gzip jenkins_home.tar
scp jenkins_home.tar.gz elsewhere:

现在,您已经获得了容器需要的数据到远程主机。您需要重新创建数据量:

ssh elsewhere
gunzip jenkins_home.tar.gz
docker run \
  --rm \
  -v jenkins_home:/jenkins_home \
  -v $PWD:/import \
  -w /jenkins_home \
  busybox \
  tar xf /import/jenkins_home.tar .

现在,远程主机具有名为jenkins_home的卷,该卷具有导出的数据的副本,您可以运行最初运行的同一Jenkins命令

ssh elsewhere
docker run \
  -p 8080:8080 -p 50000:50000 \
  -v jenkins_home:/var/jenkins_home \
  jenkins/jenkins:lts

这种方法将应用程序及其数据分开。由于您仍在使用未经修改的上游映像,因此,如果存在安全问题,并且需要升级Jenkins,则可以docker pull jenkins/jenkins:lts以获得较新的版本并重新启动容器。

docker commit几乎从来都不是最佳实践。假设您确实需要更新詹金斯;如果您按照问题提交了图像,则需要准确记住创建图像并重复该图像的操作,但是已提交图像的本质是没有记录。如果自定义映像对您的应用程序有用,请为其编写一个Dockerfile并将其提交到源代码管理。另请注意,docker commit不包含卷内容,并且您要保留的实际数据始终在卷中(可能是匿名的),因此您在问题中建议的方法不会带来所需的数据无论如何。

答案 1 :(得分:0)

您缺少在此处提供docker映像所需的卷,请从容器中预期位置的安装卷-v开始。

不完全,但仅供参考:Docker - cannot mount volume over existing file, file exists