The motivation for this post was to create a template to compose deliverables of an architecture approach that is presentable to a potential client. We wanted this template to simple enough to be picked up by any of our engineers and serve as a first step into engineering-focused consulting prior to creating more specialized documents of software architecture.
Ever since we’ve launched Dwarves Discord, we’ve been able to network with all sorts of people and share knowledge with a growing community that loves tech and blockchain just like us. We’ve created study groups for topics that explores the newest tech as well as to cover our basics as engineers. In our software modeling study group, we’ve come up with a basic structure followed up with an architecture kata that is straightforward to understand.
For our kata, we’ve chosen to do a video streaming platform directed for a startup company; more specifically, a video streaming platform that’s very similar to YouTube in that we allow any users to be curators and viewers of video content on the site. Just like in consulting, there is a lot of prep work and research that happens behind the scenes before creating an architecture presentation as the proposal for the client. For this kata, we post our research questions and notes to a Workflowy bullet. The approach is a bit impromptu and intentionally sparse, but the outlines in the Workflowy represents some of our practices of the techniques we use in the study group as well our train of thoughts on researching the topic.
The video streaming platform itself has relatively a few core basic concepts and requirements:
To ground our kata to reality, there are a few items that are of high concern to the client inquiring the architecture. As such, our most relevant objectives should consist of:
If we were in the shoes of our client, we would definitely have some reservations on building our architecture from scratch. Luckily a video streaming platform isn’t completely a foreign concept and we can look up examples of existing platforms to answer our concerns. We can take examples from Netflix, YouTube, and others.
For Netflix, they use a microservices architecture for their platform. Although the type of platform is different than what we’re looking for in our kata, it is a perfectly valid architecture approach for our practice. Just on notability, their story from a monolithic application to small, loosely coupled microservices along with open-source patterns with video-encoding were novel and industry leading enough to win them the Jury Innovation Awards in 2015. However, such an architecture is absolutely overkill for a startup.
For YouTube, their full engineering story is not as obvious, but we have a glimpse to their initial story and their direction. At first, the YouTube stack back in 2008 was a simple LAMP stack with a python library for optimization and a separate web server for video. Later down the road, it became much less of a LAMP stack and more of a Content Delivery Network (CDN) that introduced a lot more data-centric optimizations to solve scalability issues. Although an interesting story to pursue, we aren’t here to design a data center for our client.
At the end of the day, these platforms focused on content delivery optimizations to solve scalability issues rather than changing their whole system architecture - which means our architecture may be secondary to the necessity of a CDN. Notable similarities across all of these existing platforms is that use an external service or establish their own CDN in addition to having a dedicated service to transcode videos into multiple formats, despite their different system architectures. For our case, we can definitely offload video distribution work to a CDN and let them handle it. This leaves us with only a few remaining concerns:
One optimal architecture to fit our requirements would be a service-based architecture. It sits in between a monolith and a microservices architecture in a way that’s not absolutely overkill for the engineers that will have to get involved. It’s an architecture that is easy to reason about and fit domain patterns that allows us to present it to the client without immediately going into technical details. The system architecture also meets our objectives to create an architecture that is appropriate for the startup and is easy to evolve.