MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Qual é a maneira correta de definir um conjunto de réplicas do mongodb usando o docker e o fig?


Eu tive um problema semelhante, foi o que fiz. Estou usando docker-compose em vez de fig.

No meu docker-compose.
mongors:                                                                                                
  image: mongo                                                                                          
  ports:                                                                                                
    - "27017:27017"                                                                                     
  volumes:                                                                                              
   - ./mongo:mongo                                                                                      
  entrypoint: mongo/entrypoint.sh

No meu 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)};"

Verifique se é executável:
chmod +x mongo/entrypoint.sh

É um pouco chato, mas funciona :)