3 回答
TA贡献2080条经验 获得超4个赞
我使用另一个docker容器执行此操作,该容器的唯一目的是播种mongo,然后退出。我怀疑这与ebaxt的想法相同,但是当我寻找答案时,我只是想看看一个简单而又简单的示例。所以这是我的:
docker-compose.yml
mongodb:
image: mongo
ports:
- "27017:27017"
mongo-seed:
build: ./mongo-seed
links:
- mongodb
# my webserver which uses mongo (not shown in example)
webserver:
build: ./webserver
ports:
- "80:80"
links:
- mongodb
mongo-seed / Dockerfile
FROM mongo
COPY init.json /init.json
CMD mongoimport --host mongodb --db reach-engine --collection MyDummyCollection --type json --file /init.json --jsonArray
mongo-seed / init.json
[
{
"name": "Joe Smith",
"email": "jsmith@gmail.com",
"age": 40,
"admin": false
},
{
"name": "Jen Ford",
"email": "jford@gmail.com",
"age": 45,
"admin": true
}
]
TA贡献1831条经验 获得超10个赞
我发现使用Docker自定义映像和使用卷很有用,而不是创建另一个用于播种的容器。
档案结构
.
├── docker-compose.yml
├── mongo
│ ├── data
│ ├── Dockerfile
│ └── init-db.d
│ └── seed.js
Dockerfile/中提到的每个文件位置docker-compose.yml都相对于docker-compose.yml
DOCKERFILE
FROM mongo:3.6
COPY ./init-db.d/seed.js /docker-entrypoint-initdb.d
docker-compose.yml
version: '3'
services:
db:
build: ./mongo
restart: always
volumes:
- ./mongo/data:/data/db #Helps to store MongoDB data in `./mongo/data`
environment:
MONGO_INITDB_ROOT_USERNAME: {{USERNAME}}
MONGO_INITDB_ROOT_PASSWORD: {{PWD}}
MONGO_INITDB_DATABASE: {{DBNAME}}
seed.js
// Since Seeding in Mongo is done in alphabetical order... It's is important to keep
// file names alphabetically ordered, if multiple files are to be run.
db.test.drop();
db.test.insertMany([
{
_id: 1,
name: 'Tensor',
age: 6
},
{
_id: 2,
name: 'Flow',
age: 10
}
])
docker-entrypoint-initdb.d可以用于创建不同的用户和mongodb管理相关的东西,只需创建按字母顺序排序的名为js脚本的脚本即可,createUser等等。
有关如何自定义MongoDB Docker服务的更多详细信息,请阅读此
另外,最好确保您的密码和用户名不受Public的影响,不要将凭据推送到public git上,而应使用Docker Secrets。另请阅读本秘密教程
请注意,不必进入docker-swarm模式即可使用机密。撰写文件也支持秘密。检查一下
秘密也可以在MongoDB Docker Services中使用
TA贡献1797条经验 获得超6个赞
您可以使用Mongo Seeding Docker映像。
为什么?
您已经准备好使用Docker映像了
您不受JSON文件的束缚-还支持JavaScript和TypeScript文件(包括使用TypeScript进行的可选模型验证)
Docker Compose的示例用法:
version: '3'
services:
database:
image: 'mongo:3.4.10'
ports:
- '27017:27017'
api:
build: ./api/
command: npm run dev
volumes:
- ./api/src/:/app/src/
ports:
- '3000:3000'
- '9229:9229'
links:
- database
depends_on:
- database
- data_import
environment:
- &dbName DB_NAME=dbname
- &dbPort DB_PORT=27017
- &dbHost DB_HOST=database
data_import:
image: 'pkosiec/mongo-seeding:3.0.0'
environment:
- DROP_DATABASE=true
- REPLACE_ID=true
- *dbName
- *dbPort
- *dbHost
volumes:
- ./data-import/dev/:/data-import/dev/
working_dir: /data-import/dev/data/
links:
- database
depends_on:
- database
免责声明:我是这个图书馆的作者。
- 3 回答
- 0 关注
- 1070 浏览
添加回答
举报