一尘不染

在dockerized mongo上初始化数据

docker

我正在运行一个dockerized mongo容器。

我想用一些初始化的数据创建一个mongo图像。

有任何想法吗?


阅读 369

收藏
2020-06-17

共1个答案

一尘不染

首先创建一个docker卷

docker volume create --name mongostore

然后创建您的mongo容器

docker run -d --name mongo -v mongostore:/data/db mongo:latest

-v这里交换机负责安装的卷mongostore/data/db的位置,这是在蒙戈保存其数据。该卷是持久的(在主机上)。即使没有容器在运行,您也会看到mongostore的卷列出为

docker volume ls

您可以杀死该容器并创建一个新容器(与上述相同),新的mongo容器将获取先前容器的状态。

初始化卷
Mongo将初始化一个新数据库(如果不存在)。这负责在mongostore中创建初始数据。假设您要使用预先播种的数据库创建全新的环境。问题在于如何在创建mongo容器之前将数据从本地环境(例如)传输到卷。我将列出两种情况。

  1. 当地环境

您正在使用适用于Mac / Windows的Docker或Docker
Toolbox。在这种情况下,您可以轻松地将本地驱动器安装到临时容器以初始化卷。例如:

    docker run --rm -v /Users/myname/work/mongodb:/incoming \
  -v mongostore:/data alpine:3.4 cp -rp /incoming/* /data

这不适用于云存储。在这种情况下,您需要复制文件。

  1. 远程环境(AWS,GCP,Azure等)

最好将其压缩/压缩以加快上传速度。

    tar czf mongodata.tar.gz /Users/myname/work/mongodb

然后创建一个临时容器来解压缩并将文件复制到mongostore。在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

您也可以将文件复制到远程主机并从那里进行安装,但是我倾向于完全避免与远程主机进行交互。

免责声明 我是从内存中编写此文件的(没有测试)。

2020-06-17