|
Software systems are getting bigger and more complex. And we are constantly looking for ways to test code in production without risking user experience. Canary deployments is a popular mechanism for rolling out changes incrementally, allowing us to limit the blast radius in case something goes wrong. However, they’re not without limitations. Canary deployments essentially sacrifice a small portion of users for the greater good. But what if you want to gain insights without impacting any real users? That's where the dark read pattern comes in. Canary Deployments: a quick primerCanary deployments let you release updates to a small subset of users while leaving the majority untouched. The process is simple:
Canary deployments work well for testing new features or configurations in real-world settings. However, they can impact the experience for users in the canary group. If something goes wrong, they will feel it. The Dark Read patternThe Dark Read pattern takes a fundamentally different approach. It involves deploying the new version alongside the old one and executing both in parallel. The user request is served from the existing system, but the request is simultaneously executed against the new system to observe its behaviour and validate its response. This way, you can see how the new code would perform if it were handling production traffic without impacting user experience. Think of it as a “shadow test”. The goal is to see:
The Dark Read pattern in actionAt DAZN, my team was responsible for rewriting the "schedule service". It's responsible for deciding what content the user sees on the home screen and is one of the most business-critical services. Given the business criticality, we opted for the Dark Read pattern.
We ran this for several weeks and were able to identify edge cases and fix bugs without impacting any users. This pattern is very effective for backend services where the focus is on response accuracy, latency, and handling load rather than UI or frontend logic. You get the perks of testing in production without the direct risk to user experience. Why Use Dark Read Over Canary?1. No User Impacts 2. Ideal for Load Testing in Production 3. More Extensive Validation 4. Continuous Monitoring without Worrying about Rollback Drawbacks1. Increased Complexity Running two versions of code in parallel adds architectural complexity and requires infrastructure for mirroring traffic, logging, and comparing results. 2. Applicable Only to Certain Types of Tests Dark reads are great for validating logic and load handling but won’t help in testing UX, frontend changes, or how users interact with a new feature. 3. Additional Costs Duplicating traffic and processing them twice leads to increased costs, especially under high traffic. ConclusionWhile the dark read pattern doesn’t replace canary deployments, it’s a useful tool to have in your arsenal. Canary deployments provide controlled, real-world testing with an impact radius, while dark reads offer shadow testing without risking real-world effects. For critical backend changes, database migrations, or performance improvements, dark reads enable deeper insights without risking real user impact. Related posts |
Join 17K readers and level up you AWS game with just 5 mins a week.
If you use Claude Code a lot, you’ve probably run into usage limits, sometimes even in short coding sessions. But cost isn’t the only problem. In long-running sessions, the context window eventually fills up, and that can cause the agent to forget earlier decisions, lose important details, or come back from compaction with gaps in its working memory. Here are three tools worth checking out if you want to reduce token usage and make longer coding sessions possible. 1. CavemanThis is a Claude...
AI agents can now scan an entire open-source codebase for exploitable vulnerabilities in hours. Frontier models carry the complete library of known bug classes in their weights. So you can simply point an AI agent at a codebase and tell it to find zero-days. This isn't theoretical. Willy Tarreau, the HAProxy lead developer, reports that security bug reports have jumped from 2–3 per week to 5–10 per day. Greg Kroah-Hartman, the Linux kernel maintainer, described what happened: "Months ago, we...
Lambda Durable Functions makes it easy to implement business workflows using plain Lambda functions. Besides the intended use cases, they also let us implement ETL jobs without needing recursions or Step Functions. Many long-running ETL jobs have a time-consuming, sequential steps that cannot be easily parallelised. For example: Fetching data from shared databases/APIs with throughput limits. When data needs to be processed sequentially. Historically, Lambda was not a good fit for these...