How Did SoundCloud Scale Its Architecture Using BFF, Microservices & DDD?
A deep dive into the SoundCloud's journey from monolith to BFF, Microservices, and DDD. (5 minutes)
Some time ago, SoundCloud operated through a single monolithic system that managed all interactions across its web client and mobile apps.
They handled many requests, and when a new feature was added, their services became very complex.
SoundCloud started with a shared API for all platforms like iOS, Android, and Web, but soon, this approach reached its limitations because of the company’s growth.
So they embarked on a journey to transition from a monolith to a microservice architecture.
data:image/s3,"s3://crabby-images/e7679/e7679a9d14370f555156f0a37d51def1f734abfa" alt=""
Multiplayer - Sponsor
Multiplayer provides tools for teams working on distributed systems:
OpenTelemetry powered auto-documentation of your system architecture
Deep session replays for effortless platform debugging
Collaborative system design with interactive diagrams and notebooks
Transition To Microservices And Backend-For-Frontend (BFF)
Because of the need for scalability both from an organizational and operational point, SoundClound decided to transition to a microservice architecture.
They started breaking down the monolith into smaller, more manageable services, each responsible for a specific feature.
SoundCloud also introduced a BFF architecture. This allowed each team to develop APIs tailored to the needs of different frontends - iOS, Android, Web, etc.
Using BFF helped the teams to be more autonomous and effective.
data:image/s3,"s3://crabby-images/51c5e/51c5e76274a779a5f64980d1a727a74a104c25ee" alt=""
Challenges With BFF And Introduction of VAS
Despite the initial success with the upgraded architecture, SoundCloud faced challenges like duplication of business and authorization logic across multiple BFFs.
This duplication and complexity led to maintenance challenges and synchronization issues.
SoundCloud addressed this challenges by introducing Value-Added-Services (VAS).
VAS operates on a few core principles from Domain-Driven Design (DDD) like domains, entities, value objects, and aggregators.
You can think of a VAS like a separated service tailored to a specific domain like “Notifications”, “Songs”, “Tracks”, “Preferences”, etc.
Here’s is a high-level diagram outlining the overall architecture after this change:
data:image/s3,"s3://crabby-images/3642e/3642e7d85e8adb2639b079f33e822131f951aa29" alt=""
With the introduction of Value-Added-Services (VAS), SoundCloud managed to centralize the logic related to entity handling.
This reduced the duplication and improved the system coherence.
VAS managed entities like Tracks, Users, Comments, etc., and their life cycles.
Each VAS returned an aggregate that included all the necessary metadata.
This new improvement in the design significantly streamlined the operations.
data:image/s3,"s3://crabby-images/d066f/d066f123daf8b3cee20ec75c9bfc25bda816dffb" alt=""
And here is a diagram of an example of the Playlists VAS and its usage:
data:image/s3,"s3://crabby-images/c1950/c19506cff6b77c02fb0aa19050c25f710dffaff6" alt=""
The Impact Of VAS On System Design
The implementation of VAS changed how SoundCloud handled data.
This change offered a more centralized approach where entities could be managed through commands and queries, following the Command Query Responsibility Segregation (CQRS) pattern.
The separation allowed different parts of the system to evolve independently, improving maintainability and scalability.
For example, operations that altered the entity’s state were handled separately from those that retrieved data. This ensured efficient processing and consistency.
Here is an example of Tracks VAS and querying different parts of the Aggregate from several services:
data:image/s3,"s3://crabby-images/6c7f1/6c7f109650ab8ffb76fecb99d63d1400b8e73ef0" alt=""
Here is an example of liking and disliking a Track through Tracks VAS using commands:
data:image/s3,"s3://crabby-images/6df70/6df700e019673dd7ed299caab1ed32c2ad8bb9ae" alt=""
Evolution To Domain Gateways
As with the SoundCloud business growth and new business domains, a new need has emerged - handle the same entities in different business contexts.
To handle this, SoundCloud introduced a Domain Gateway - a tailored VAT to serve the specific business needs and context.
Each gateway was managed by a different team, providing customized views and operations on entities like Tracks, which could be used differently by Consumers and Creators.
This new approach minimized the cross-team dependencies and maximized the domain-specific enhancements.
data:image/s3,"s3://crabby-images/bf85c/bf85c8ba1eaae7f425fc3598016b4cb301e5b31d" alt=""
📋 Recap
SoundCloud transitioned from monolithic to microservice architecture to improve scalability and maintainability.
They implemented BFF pattern to optimize APIs for different clients, enhancing team autonomy and operational scalability.
SoundCloud introduced VAS (DDD based services) to centralize core functionalities and reduce duplication and complexity.
They developed Domain Gateways to manage and centralize services for specific business domains, further improving scalability and system coherence.
That's all for today. I hope this was helpful. ✌️
👋 Let’s connect
You can find me on LinkedIn, Twitter(X), Bluesky, or Threads.
I share daily practical tips to level up your skills and become a better engineer.
Thank you for being a great supporter, reader, and for your help in growing to 18.3K+ subscribers this week 🙏
You can also hit the like ❤️ button at the bottom to help support me or share this with a friend. It helps me a lot! 🙏
📚 References
https://developers.soundcloud.com/blog/service-architecture-1
https://developers.soundcloud.com/blog/service-architecture-2
https://developers.soundcloud.com/blog/service-architecture-3
https://learn.microsoft.com/en-us/azure/architecture/patterns/backends-for-frontends
https://learn.microsoft.com/en-us/azure/architecture/patterns/cqrs
Thanks for sharing this Petar!
First time I have seen these Value Added Services and still not clear to me what is the benefits that bring to the architecture.
If I understand correctly, are kind of a proxy, for other microservices which are the ones that really manage each entity.
I have to investigate more to understand the value they bring.
Thanks!
Very insightful Petar