A Replica Set of MongoDB running in a Docker container
The key motivation for this image is to have a ready-made replica set of MongoDB running inside docker container for CI tests and local development.
To run the container, execute the following command:
docker run -d -p 27017:27017 -p 27018:27018 -p 27019:27019 candis/mongo-replica-set
If you prefer, use Docker Compose instead:
docker-compose up -d
Wait for 30 to 35 seconds in order to properly start all database instances and replica-set initialization.
Additionally, you can pass an env variable called HOST
when running the container to configure the replica's hostname in docker. By default, it uses localhost
.
Once ready, the replica-set can be accessed using the following connection string:
mongodb://localhost:27017,localhost:27018,localhost:27019/?replicaSet=rs0&readPreference=primary&ssl=false
If you're connecting from your host machine, you might need to set a new alias within /etc/hosts
:
# /etc/hosts
127.0.0.1 HOST # where HOST is the value passed as env variable to the container