sql >> Database >  >> NoSQL >> MongoDB

Wat is de juiste manier om een ​​mongodb-replicaset in te stellen met behulp van docker en fig?

Ik had een soortgelijk probleem, dit is wat ik heb gedaan. Ik gebruik docker-compose in plaats van fig.

In mijn docker-compose.

mongors:                                                                                                
  image: mongo                                                                                          
  ports:                                                                                                
    - "27017:27017"                                                                                     
  volumes:                                                                                              
   - ./mongo:mongo                                                                                      
  entrypoint: mongo/entrypoint.sh

In mijn entrypoint.sh:

#!/bin/bash
mongod --port 27018 --replSet rs0 --fork --syslog --smallfiles
mongo --port 27018 --eval "rs.initiate({_id : 'rs0', members : [{_id : 0, host : 'localhost:27018'}]})"
mongo --port 27018 --eval "while(true) {if (rs.status().ok) break;sleep(1000)};"

Zorg ervoor dat het uitvoerbaar is:

chmod +x mongo/entrypoint.sh

Het is een beetje hacky, maar het werkt :)



  1. MongoDB-aggregatie - $ groeperen op datum, zelfs als deze niet bestaat

  2. C# + MongoDB - ObjectId zonder gebruik te maken van MongoDB DataTypes/Attributes

  3. Mongo Query is mislukt met foutcode 13 en foutmelding 'niet geautoriseerd'

  4. MongoEngine:velden toevoegen aan dynamisch document