我正在运行一个dockerized mongo容器。
我想用一些初始化的数据创建一个mongo图像。
有任何想法吗?
首先创建一个docker卷
docker volume create --name mongostore
然后创建您的mongo容器
docker run -d --name mongo -v mongostore:/data/db mongo:latest
在-v这里交换机负责安装的卷mongostore在/data/db的位置,这是在蒙戈保存其数据。该卷是持久的(在主机上)。即使没有容器在运行,您也会看到mongostore的卷列出为
-v
mongostore
/data/db
docker volume ls
您可以杀死该容器并创建一个新容器(与上述相同),新的mongo容器将获取先前容器的状态。
初始化卷 Mongo将初始化一个新数据库(如果不存在)。这负责在mongostore中创建初始数据。假设您要使用预先播种的数据库创建全新的环境。问题在于如何在创建mongo容器之前将数据从本地环境(例如)传输到卷。我将列出两种情况。
您正在使用适用于Mac / Windows的Docker或Docker Toolbox。在这种情况下,您可以轻松地将本地驱动器安装到临时容器以初始化卷。例如:
docker run --rm -v /Users/myname/work/mongodb:/incoming \ -v mongostore:/data alpine:3.4 cp -rp /incoming/* /data
这不适用于云存储。在这种情况下,您需要复制文件。
最好将其压缩/压缩以加快上传速度。
tar czf mongodata.tar.gz /Users/myname/work/mongodb
然后创建一个临时容器来解压缩并将文件复制到mongostore。在tail -f /dev/null刚刚可以确保容器不退出。
tail -f /dev/null
docker run -d --name temp -v mongostore:/data alpine:3.4 tail -f /dev/null
复制文件到它
docker cp mongodata.tar.gz temp:.
解压缩并移至该卷
docker exec temp tar xzf mongodata.tar.gz && cp -rp mongodb/* /data
清理
docker rm temp
您也可以将文件复制到远程主机并从那里进行安装,但是我倾向于完全避免与远程主机进行交互。
免责声明 我是从内存中编写此文件的(没有测试)。