How Magic Circle Scaled Up To 2M Games With Cloudflare and Neon
The team ships new iterations daily supported by their serverless infra. The cherry on top: Neon branching
“We’re a small team, but we’re scaling quickly and doing a lot. We’re shipping multiple times a day— to do that, we need to test stuff quickly and merge to main very quickly as well. Neon branches are a game changer for this.”
(Avi Romanoff, Founder at Magic Circle)
Magic Circle is a new game studio that helps you connect with friends online through a collection of fun multiplayer games, available on the web and inside Discord. They’re building a relaxed, wonderfully silly low-pressure environment where friend groups hang out online and take a break from their busy schedules.
Last July, Magic Circle won Discord’s “Best Chill/Party Game” competition. Their games are now accessible from any Discord server, private messages, or even group video calls—perfect for when you and your team need a break:Â
Scaling to millions of games with an infra bill below $500
​​“I’ve been building multiplayer games for a long time, and the database question has always been an interesting one. Traffic is often spikey, so in an ideal world, you’d have many small servers that spin up and down based on demand—but the challenge is creating a database that matches that setup, yet still acts as a single source of truth. The solution for us has been Neon and Cloudflare Durable Objects.”
(Avi Romanoff, Founder at Magic Circle)Â
Magic Circle’s entire infrastructure is designed to be lightweight and cost-efficient: a serverless architecture was a no-brainer. By combining Cloudflare and Neon, Magic Circle facilitates millions of game sessions and requests at a fraction of the cost of traditional setups.
This is how they do it:Â
- Cloudflare Workers for game logic. These edge workers minimize latency for players across 30+ countries by processing requests and responses closer to users.
- Cloudflare Durable Objects for session management. Durable Objects are a cornerstone of Magic Circle’s architecture. They handle state management for multiplayer sessions, allowing each game session to act effectively as a “tiny server”.Â
- Routing for versioning. Cloudflare also plays a role in routing players to the correct version of the game. This allows different groups to play on different versions simultaneously, essential for Magic Circle’s fast development cycles (more about this below).Â
- Neon as the relational database. Neon is the serverless Postgres database storing core player data like accounts, game progress, stats, and in-game currency. Gameplay logic is managed at the edge, and Neon handles all persistent info.
Bringing fast software lifecycles to gaming
“While games typically ship on multi-week release cycles, we want to ship as fast as possible — so we built a pretty cool in-house game platform on top of Cloudflare and Neon that lets us deploy multiple times a day, in minutes, with zero downtime.”
(Avi Romanoff, Founder at Magic Circle)
Something unique about Magic Circle’s development approach is how they bring a rapid iteration strategy—typically seen in web development—to the world of multiplayer gaming. Their workflow enables them to ship updates multiple times a day, with Neon branches serving as a cornerstone of this process.Â
In Neon, users can instantly create database branches, which act as fully isolated copies of the database, including both data and schema. These branches are widely used for creating development and testing environments that are ephemeral and cost-effective, allowing teams to iterate quickly on features, fix bugs, or test database schema changes.
This is exactly how Magic Circle uses branching. Not only do they iterate multiple times a day, but they also frequently ship entirely new games in under a week. This process involves updating game logic, introducing new UI elements, and modifying database structures to support new gameplay mechanics. Such speed would be nearly impossible with a traditional managed database setup tied to a monolithic server, but Neon brings them a more modern workflow where the database is no longer a bottleneck.
How Magic Circle uses Neon branches to ship fasterÂ
“We have a bot that comments on every pull request on GitHub every time there’s a new PR branch. We get a totally isolated copy to test code changes even when they include database migrations. We can test all changes in real data and ensure that by the time we actually merge the PR to main, things really work”Â
(Avi Romanoff, Founder at Magic Circle)
Let’s take a closer look at Magic Circle’s branching workflows.Â
1/ A Neon branch is created per every PR using the GitHub Integration.Â
- Each pull request in GitHub automatically triggers the creation of a dedicated Neon branch via a GitHub Action.
- Any schema migrations included in the PR are executed against this branch, ensuring they work as intended without disrupting production.
- A GitHub bot comments on the PR with the branch details.Â
2/ End-to-end testing is done against a Neon branch first.Â
- Neon branches are fully integrated into Magic Circle’s infrastructure, enabling end-to-end testing in environments that mimic production.
- The testing setup includes the PR code, live game servers, and the isolated Neon branch, ensuring thorough validation of new features and database changes.
- This allows the team to validate multiplayer features and gameplay mechanics before merging to prod, ensuring smooth operation across all components without the hiccups associated with testing on seed data.Â
3/ Every developer gets their own Neon branch as an isolated environment.Â
- Each developer in the team also has access to a dedicated Neon branch for their dev needs.
- These branches are linked to personal development environments using Cloudflare Tunnel, allowing developers to run fully isolated versions of the game with a live database backend.
- Developers can test their changes without interfering with others, and each dev environment can be personalized while ensuring that every branch mirrors the production database.Â
4/ Rollbacks are executed fast via branches.Â
- Even if this is not needed often (🤞) Neon’s Branch Restore makes rollbacks straightforward and reliable without downtime.Â
- In the very rare case when a problematic commit is indeed merged to production, Magic Circle creates a new Neon branch from a specific point in time to revert to a known good state.Â
- This process is ready immediately, minimizing potential downtime—something essential in gaming.
Try it yourselfÂ
Database branching workflows might seem a bit outlandish at first, but once you try them, you’ll be converted. With Neon’s Free Plan, you can create up to 10 branches per project to get a feel for it—sign up here. It only takes seconds and you don’t need a credit card.Â
Once you’re set up, don’t forget to play Magic Circle with your friends in Discord or on the web at magiccircle.gg . To learn more about them and their company, give this podcast a listen.