Mongodb Docker – Creazione di utenti iniziali e creazione di strutture iniziali

Sto cercando di build un contenitore mongodb con un utente e una struttura di database di base già configurata (da Dockerfile).

Ecco il mio Dockerfile:

FROM mongo:latest RUN mongo localhost:27017 "db.help()" 

(minificato per scopi di prova).

Continuo a ricevere l'errore:

 connecting to: localhost:27017 2017-06-01T14:49:34.353+0000 W NETWORK [thread1] Failed to connect to 127.0.0.1:27017, in(checking socket for error after poll), reason: Connection refused 2017-06-01T14:49:34.353+0000 E QUERY [thread1] Error: couldn't connect to server localhost:27017, connection attempt failed : [email protected]/mongo/shell/mongo.js:237:13 @(connect):1:6 exception: connect failed 

… e il contenitore non riesce a build. Non sono nemless sicuro di come controllare i registri dal momento che sto costruendo da Dockerfile e una volta che il contenitore non riesce a build, non c'è modo di entrare per controllare i registri.

Tuttavia, se rimuovo questo command RUN e faccio manualmente:

 docker -exec -it mongodb_container bash mongo > db.help() 

…Funziona.

Ho provato a impostare la properties; a mongodb: mongodb e ho cercato di muovere il registro e il path db per ~ / db dir senza successo.

PS: sto usando il compositore di docker. Vorrei farlo con compositori componibili in modo che gli sviluppatori non debbano gestire le stesse cose.

Ecco il segmento componibile:

 mongodb: build: ./mongodb ports: - "27017:27017" 

EDIT:

Se lo cambio a 0.0.0.0:27017 , ottengo questo errore:

 MongoDB shell version v3.4.4 connecting to: 0.0.0.0:27017 2017-06-01T15:52:52.806+0000 E QUERY [thread1] Error: couldn't connect to server 0.0.0.0:27017, address resolved to 0.0.0.0 : [email protected]/mongo/shell/mongo.js:237:13 @(connect):1:6 exception: connect failed 

EDIT2:

Quando provo con il seguente Dockerfile:

 FROM mongo:latest RUN mkdir -p /data/db2 \ && echo "dbpath = /data/db2" > /etc/mongodb.conf \ && chown -R mongodb:mongodb /data/db2 COPY . /data/db2 RUN mongod --fork --logpath /var/log/mongodb.log --dbpath /data/db2 

MongoDB inizia inizialmente, ma poi esce con l'output:

 mongodb_1 | 2017-06-01T15:55:52.955+0000 I CONTROL [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data/db 64-bit host=64a317041edd mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] db version v3.4.4 mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] git version: 888390515874a9debd1b6c5d36559ca86b44babd mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] OpenSSL version: OpenSSL 1.0.1t 3 May 2016 mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] allocator: tcmalloc mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] modules: none mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] build environment: mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] distmod: debian81 mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] distarch: x86_64 mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] target_arch: x86_64 mongodb_1 | 2017-06-01T15:55:52.956+0000 I CONTROL [initandlisten] options: {} mongodb_1 | 2017-06-01T15:55:52.964+0000 E NETWORK [initandlisten] Failed to unlink socket file /tmp/mongodb-27017.sock Operation not permitted mongodb_1 | 2017-06-01T15:55:52.964+0000 I - [initandlisten] Fatal Assertion 28578 at src/mongo/util/net/listen.cpp 194 mongodb_1 | 2017-06-01T15:55:52.964+0000 I - [initandlisten] mongodb_1 | mongodb_1 | ***aborting after fassert() failure mongodb_1 | mongodb_1 | stuff_mongodb_1 exited with code 14 

È ansible utilizzare un approccio leggermente diverso. È ansible alimentare mongo con i dati each volta che inizia la prima volta. È ansible realizzare che utilizzando un contenitore auxiliare mongo-seed .

Vedi questo approccio:

 version: "2" mongodb: image: mongo ports: - "27017:27017" mongo-seed: image: mongo command: mongoimport --host mongodb --db example-db --collection MyDummyCollection --type json --file /init.json --jsonArray volumes: - ./init.json:/init.json 

init.json

 [ { "name": "Joe Smith", "email": "[email protected]", "age": 40, "admin": false }, { "name": "Jen Ford", "email": "[email protected]", "age": 45, "admin": true } ] 

Correre come:

 docker-compose up docker-compose exec mongodb mongo > use example-db > db.MyDummyCollection.find() { "_id" : ObjectId("592f5496fcdcafc0a8e0e0c8"), "name" : "Joe Smith", "email" : "[email protected]", "age" : 40, "admin" : false } { "_id" : ObjectId("592f5496fcdcafc0a8e0e0c9"), "name" : "Jen Ford", "email" : "[email protected]", "age" : 45, "admin" : true } 

Ho preso il codice da qui , ma ho migliorato senza bisogno di un Dockerfile per il seme.