Visualize Your Software Architecture With The C4 Model

Visualize Your Software Architecture With The C4 Model

4 min read ·

Thank you to our sponsors who keep this newsletter free to the reader:

Today's issue is sponsored by IcePanel. IcePanel is a collaborative C4 model modelling & diagramming tool that helps explain complex software systems. With an interactive map, you can align your software engineering & product teams on technical decisions across the business.

And by Rebus Pro. Rebus is a free .NET "service bus", and Rebus Pro is the perfect one-up for serious Rebus users. Use Fleet Manager to get Slack alerts when something fails and retry dead-lettered messages with a click of the mouse.

Software architecture diagrams are a great way to communicate how you are planning to build a software system or how an existing software system works.

However, the majority of software architecture diagrams I've seen are a total mess.

If only there was a standard way to visualize your software architecture...

Enter the C4 model, which stands for context, containers, components, and code.

The C4 model is a lightweight approach to describing your software architecture.

And it's essentially just two things, a predefined set of common abstractions and four diagram types:

  • Context diagram - high-level view of the system
  • Container diagram - shows the objects running inside a system
  • Component diagram - shows the building blocks that make each container
  • Code diagram - rarely used, typically UML or ER diagram

Let's see how we can use the C4 model to visualize our software architecture.

First You Need Abstractions

Before we dive into the C4 diagrams, we first need to understand the ubiquitous language of the C4 model.

A software system is made up of one or more containers (applications and data stores), each of which contains one or more components, which in turn are implemented by one or more code elements (classes, interfaces, objects, functions, etc). And people may use the software systems that we build.

The C4 model defines a set of abstractions that you can use to describe your software systems:

  • Person - the end user using your system
  • Software system - highest level of abstraction that delivers value to end users
  • Container - applications and data stores that make up a system
  • Component - building blocks/modules that make up the container

With these high-level concepts in place, let's take a look at how to use them in our C4 diagrams.

System Context Diagram

The System Context diagram is a high-level view of your software system.

It shows your software system as the central part, and any external systems and users that your system interacts with.

It should be technology agnostic, and the focus on the people and software systems instead of low-level details.

The intended audience for the System Context Diagram is everybody.

If you can show it to non-technical people and they are able to understand it, then you know you're on the right track.

Container Diagram

When you zoom into one software system, you get to the Container diagram.

Your software system is comprised of multiple running parts - containers.

A container can be a:

  • Web application
  • Single-page application
  • Database
  • File system
  • Object store
  • Message broker

You can look at a container as a deployment unit that executes code or stores data.

The Container diagram shows the high-level view of the software architecture and the major technology choices.

The Container diagram is intended for technical people inside and outside of the software development team:

  • Software architects
  • Developers
  • Operations/support staff

Component Diagram

Next you can zoom into an individual container to decompose it into its building blocks.

The Component diagram show the individual components that make up a container:

  • What each of the components are
  • The technology and implementation details

The Component diagram is intended for software architects and developers.

Code Diagram

Finally, you can zoom into each component to show how it is implemented with code, typically using a UML class diagram or an ER diagram.

This level is rarely used as it goes into too much technical detail for most use cases.

However, there are supplementary diagrams that can be useful to fill in missing information by showcasing:

  • Sequence of events
  • Deployment information
  • How systems interact at a higher level

It's only recommended for the most important or complex components.

Of course, the target audience are software architects and developers.

Takeaway

The C4 model is a tool for visual and verbal communication, enabling your team to talk in the same language and have a common understanding of the design.

It's valuable for many reasons, to name a few:

  • Product and business people benefit from understanding user behavior at the Context level
  • Context and Container diagrams provide a simple view of how software systems work
  • New developers can quickly understand system flows

Now that you understand what the C4 model is, there's one question left to answer.

Should you use the C4 model to express your software architecture?

I can't give you a definitive answer.

I used it with a lot of success.

But I think you should at least give it a try.

You can learn more about the C4 model here.

Thank you for reading, and have an awesome Saturday.


Whenever you're ready, there are 4 ways I can help you:

  1. (COMING SOON) REST APIs in ASP.NET Core: You will learn how to build production-ready REST APIs using the latest ASP.NET Core features and best practices. It includes a fully functional UI application that we'll integrate with the REST API. Join the waitlist!
  2. Pragmatic Clean Architecture: Join 3,600+ students in this comprehensive course that will teach you the system I use to ship production-ready applications using Clean Architecture. Learn how to apply the best practices of modern software architecture.
  3. Modular Monolith Architecture: Join 1,600+ engineers in this in-depth course that will transform the way you build modern systems. You will learn the best practices for applying the Modular Monolith architecture in a real-world scenario.
  4. Patreon Community: Join a community of 1,000+ engineers and software architects. You will also unlock access to the source code I use in my YouTube videos, early access to future videos, and exclusive discounts for my courses.
  5. Promote yourself to 61,000+ subscribers by sponsoring this newsletter.

Become a Better .NET Software Engineer

Join 61,000+ engineers who are improving their skills every Saturday morning.