我正在尝试分发在几个链接的容器中运行的一组连接的应用程序,这些容器包括一个mongo数据库,该数据库需要:
- 分发包含一些种子数据;
- 允许用户添加其他数据。
理想情况下,数据还将保存在链接的数据卷容器中。
我可以mongo
使用mongo
不装载任何卷的基本实例(dockerhub映像:psychemedia/mongo_nomount
-本质上是不带该VOLUME /data/db
语句的基本mongo Dockerfile )和Dockerfile
配置的方式将数据放入容器中:
ADD . /files
WORKDIR /files
RUN mkdir -p /data/db && mongod --fork --logpath=/tmp/mongodb.log && sleep 20 && \
mongoimport --db testdb --collection testcoll --type csv --headerline --file ./testdata.csv #&& mongod --shutdown
其中与Dockerfile./testdata.csv
位于同一目录(./mongo-with-data
)中。
我的docker-compose配置文件包括以下内容:
mongo:
#image: mongo
build: ./mongo-with-data
ports:
- "27017:27017"
#Ideally we should be able to mount this against a host directory
#volumes:
# - ./db/mongo/:/data/db
#volumes_from:
# - devmongodata
#devmongodata:
# command: echo created
# image: busybox
# volumes:
# - /data/db
每当我尝试装入VOLUME时,似乎就好像/data/db
删除了原始种子数据(存储在其中)一样。我猜想当一个卷安装到/data/db
它上时,它会替换当前存在的任何东西。
也就是说,docker用户指南建议:创建容器时将初始化卷。如果容器的基本映像在指定的安装点包含数据,则在卷初始化时将现有数据复制到新卷中?因此,如果我将VOLUME命令放在种子RUN
命令之后,我希望数据能够持久保存吗?
那我在做什么错?
从长远来看,我想自动化几个链接容器的构建,然后分发一个Vagrantfile
/ docker-compose的YAML文件,该文件将启动一组链接应用程序,其中包括一个mongo
带有(部分预先填充)持久数据容器。