All Templates / Storage
MongoDB Replica Set
Instant MongoDB replica set for high availability and redundancy.
mongo1
railwayapp-templates/mongo-replica-set
Just deployed
/data
mongo3
railwayapp-templates/mongo-replica-set
Just deployed
/data
mongo2
railwayapp-templates/mongo-replica-set
Just deployed
/data
init service - delete when done
railwayapp-templates/mongo-replica-set
Just deployed
This template deploys a MongoDB replica set for a more highly available and redundant data layer.
All communication between nodes is done over the private network.
To tune the configuration of the MongoDB nodes, refer to the MongoDB documentation or the documentation page in Docker Hub.
The MongoDB replica set is deployed using keyfile authentication.
To connect to the replica set from another service in Railway, you should create a URI in the service's environment variables that includes all nodes. As an example:
MONGO_HOSTS=${{mongo1.RAILWAY_PRIVATE_DOMAIN}}:27017,${{mongo2.RAILWAY_PRIVATE_DOMAIN}}:27017,${{mongo3.RAILWAY_PRIVATE_DOMAIN}}:27017
REPLICA_SET_NAME=${{mongo1.REPLICA_SET_NAME}}
MONGO_URI=mongodb://${{mongo1.MONGO_INITDB_ROOT_USERNAME}}:${{mongo1.MONGO_INITDB_ROOT_PASSWORD}}@${{MONGO_HOSTS}}/?replicaSet=${{REPLICA_SET_NAME}}
With these variables set, you can then reference the MONGO_URI
environment variable when configuring the client in your service code. You can find some examples here.
NOTE: If you need to connect to the set from your local machine, or from a service outside of the Railway project in which it is deployed, you will need to setup a tunnel into the Railway private network. Check out this tutorial for information on how to use Tailscale as a tunnel.
The source for this template can be found in the Railway Templates GitHub.
The MongoDB nodes are built almost directly from the official MongoDB image in Docker Hub, with the only customization being the setup of the Keyfile.
Template Content
init service - delete when done
railwayapp-templates/mongo-replica-setDetails
Railway Templates
Created on May 29, 2024
130 total projects
26 active projects
100% success on recent deploys
Shell, JavaScript, Python, Dockerfile, Procfile
Storage
More templates in this category