(Re)Introducing mirrord

The Dev Loop (or: know your enemy)

Imagine youāre a backend developer at post series B SaaS soonicorn. Youāve spent half a sprint adding a new feature to your microservice. Youāve thoroughly researched possible inputs and database states and built an elaborate test suite. Your code was mercilessly reviewed by two of your teammates. Finally, the tests pass, the pull request is approved, and as a final verification, you deploy your new code to the staging environmentā¦
Where it crashes almost immediately. Turns out you forgot to test some obscure configuration, or some complex database state that would only ever occur on a mature, complex environment - like staging, and unlike your local machine. So you roll the service back on staging, fix the bug, write some more tests, get it reviewed again, build the code, deploy it to staging⦠and it crashes again. While you were fixing the bug, your teammate deployed a new version of some other microservice - except they’re not as thorough a tester as you are, and the new version is broken, so you canāt test your own service. You wait for them to roll their service back to a working version, the sprint is long over, and youāve started on your next feature during your downtime so now youāre dividing your focus between two things.
The worst part being that you know itās going to happen again next sprint.
mirrord (or: how you win)
Iāve encountered some variation of the dev loop at every startup Iāve ever worked in, and itās this pain exactly that weāre trying to solve with mirrord. mirrord runs in two places - on your local development machine, and in your staging environment. By wrapping your local process and hooking system calls, it lets you plug your process non-invasively into that serviceās instance on the staging environment.
Simply put, mirrord lets you run a local process in the context of your cloud service. This means you can test your code on staging, without actually deploying it there. Not only does it save you the hassle of deployment every time you make a change, but it also keeps the staging environment free from untested versions, and constantly usable for everyone else in the organization.
Getting Started (and: other practical info)
Today weāre releasing mirrord 2.0, which supports incoming traffic. That means whatever traffic reaches your service in staging is duplicated by mirrord and sent to your local process. Weāll soon be adding support for outgoing traffic, file access, and environment variables - everything needed for your local process to āthinkā itās running on the staging environment. All you need to run mirrord is kubectl access to your staging environment1. You can use it as either a CLI tool, or an extension for VS Code (IntelliJ support is on the way). Try it out here, and let us know what you think at hi@metalbear.com, or in our repo!
- note that mirrord doesnāt install anything persistent in your Kubernetes cluster. It runs a job that self-deletes when mirrord terminates. ↩︎ 

