DB Branching
How to use mirrord to spin up an isolated DB branch for safe development and testing DB migrations
This feature is available to users on the Team and Enterprise pricing plans.
The db_branches feature in mirrord lets developers spin up an isolated DB branch that mirrors the remote DB, while running safely in isolation. This allows schema changes, migrations, and experiments without impacting teammates or shared environments. Currently, the feature is limited to MySQL, PostgreSQL, MongoDB databases for remote usage, and Redis database for local development.
When is this useful?
Running schema migrations safely Developers can test migrations and schema changes without risking corruption of the remote databases.
Experimenting locally Developers get a branch of the remote DB connected to their local app automatically - no admin setup required.
Collaborating with teammates If a branch already exists (with the same ID), mirrord reuses it. Developers can share branches as needed.
Prerequisites
Before you start, make sure you have:
Minimum versions installed:
MySQL: Operator
3.129.0, mirrord CLI3.160.0and operator Helm chart1.37.0withoperator.mysqlBranchingvalue set totrue.PostgreSQL: Operator
3.131.0, mirrord CLI3.175.0and operator Helm chart1.40.2withoperator.pgBranchingvalue set totrue.MongoDB: Operator
3.137.0, mirrord CLI3.183.0and operator Helm chart1.44.0withoperator.mongoBranchingvalue set totrue.Redis: mirrord CLI
3.180.0(no operator or chart version requirements, since Redis is supported only via a local DB branch).
Your local application is using environment variables or Kubernetes Secrets to store DB connection strings or individual connection parameters.
mirrord installed and working.
Configuring db_branches
db_branchesDevelopers define branches in their mirrord.json:
Key Fields
id: When reused, mirrord reattaches to the same branch as long as the time-to-live (TTL) has not expired. This allows multiple sessions to share the same database branch. To prevent accidental reuse of another user's branch, it is recommended to assign a unique value (for example, a UUID) as the identifier. (Theidfield is not used for local Redis instances and has no effect on database selection or reuse)location: Supported values areremoteandlocal. The default isremote.remoteapplies only when thetypefield is set tomysql,pg, ormongodb, whilelocalapplies only whentypeis set toredis.type: Supported values are"mysql","pg","mongodb", and"redis".version: Database engine version.name: Remote database name to clone, the override URL usesnameso the connection URL looks like .../dbname. If name is ommited, the override URL just points to the database server; the application must select the DB manually in that case.ttl_secs: Override for branch time-to-live (TTL). The default is 5 minutes. The maximum allowed is 15 minutes. If you set a value above 15, mirrord will automatically fall back to 15 minutes.connection: Describes how to locate the source database connection details. Supports a full connection URL or individual connection parameters. See Advanced Configuration for details.copy.mode: Allows developers to control how the database is cloned when creating a branch, see Advanced Configurationcreation_timeout_secs: Override for branch creation timeout. The default is 60 seconds.iam_auth: Optional IAM authentication for AWS RDS or GCP Cloud SQL. See Advanced Configuration for details.local.port: Currently only for Local Redis. Sessions that use the same port share a single local Redis database. When a new session starts on that port, it creates a new database instance that replaces the existing one.
Running With DB Branches
Run your app with mirrord and set the
db_branchesfield in the mirrord configuration file.mirrord will spin up a database branch according to the following rules:
Reusing an existing branch: If you provide an ID that matches an existing branch and its TTL hasn’t expired, mirrord will reuse that branch. When this happens, mirrord will notify you:
This means you’re connecting to an existing branch, not a fresh isolated one.
Creating a new branch: If no ID is specified, or if you choose a new, non-existing ID, mirrord will create a fresh, empty database branch.
mirrord will override your DB environment variable with the branch's connection URL, so the app connects to the branch, not to the source db. This setup reduces the risk of accidental writes reaching the source database by directing activity toward an isolated branch.
The branch will be destroyed automatically when the TTL is reached and the branch is not in use (reconnecting to the same branch again extends its lifetime).
Local Redis
mirrord can spin up a local Redis instance, automatically redirecting your app's Redis traffic to it.
mirrord overrides the env variable to point to localhost:<port> and cleans up the Redis instance on exit.
FAQ
Q: Why does my connection time out? A: By default, branch databases have SSL disabled. Check if your client is specifically requesting SSL.
Q: How do I use IAM authentication instead of passwords? A: mirrord supports IAM authentication for AWS RDS and GCP Cloud SQL. Just add "iam_auth": { "type": "aws_rds" } or "iam_auth": { "type": "gcp_cloud_sql" } — mirrord automatically uses standard env vars like AWS_REGION or GOOGLE_APPLICATION_CREDENTIALS from your target pod. See IAM Authentication for details.
What's next?
Next, check out the Advanced Configuration and DB Branch Management sections to learn more about customization and command options.
Last updated
Was this helpful?

