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": "[email protected]",
"age": 40,
"admin": false
},
{
"name": "Jen Ford",
"email": "[email protected]",
"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 關注
- 1113 瀏覽
添加回答
舉報