C4model is a methodology to express software architectures in block diagram shapes...Kind of graphical notation or expressing language for modelling soft architectures.
The zoom-out perspective of the whole system in the biggest scale. Detail isn't important here as this is your zoomed out view showing a big picture of the system landscape. The focus should be on people (actors, roles, personas, etc) and software systems rather than technologies, protocols and other low-level details. It's the sort of diagram that you could show to non-technical people.
So in short, each shape demonstrates below meanings: . . .
example: This is an example System Context diagram for a fictional Internet Banking System. It shows the people who use it, and the other software systems that the Internet Banking System has a relationship with. Personal Customers of the bank use the Internet Banking System to view information about their bank accounts, and to make payments. The Internet Banking System itself uses the bank's existing Mainframe Banking System to do this, and uses the bank's existing E-mail System to send e-mails to customers.
You zoom in a bit and you are in second level. This level of visualization is shown inside a dash-line boundry with container blocks.Once you understand how your system fits in to the overall IT environment, a really useful next step is to zoom-in to the system boundary with a Container diagram.
Example:
This is an example Container diagram for a fictional Internet Banking System. It shows that the Internet Banking System (the dashed box) is made up of five containers: a server-side Web Application, a Single-Page Application, a Mobile App, a server-side API Application, and a Database. The Web Application is a Java/Spring MVC web application that simply serves static content (HTML, CSS and JavaScript), including the content that makes up the Single-Page Application. The Single-Page Application is an Angular application that runs in the customer's web browser, providing all of the Internet banking features. Alternatively, customers can use the cross-platform Xamarin Mobile App, to access a subset of the Internet banking functionality.
Both the Single-Page Application and Mobile App use a JSON/HTTPS API, which is provided by another Java/Spring MVC application running on the server. The API Application gets user information from the Database (a relational database schema). The API Application also communicates with the existing Mainframe Banking System, using a proprietary XML/HTTPS interface, to get information about bank accounts or make transactions. The API Application also uses the existing E-mail System if it needs to send e-mails to customers.
You can zoom in more into level-2 containers/blocks. shows how a container is made up of a number of "components"....Symbol diagrams below listed:
Example: This is an example Component diagram for a fictional Internet Banking System, showing some (rather than all) of the components within the API Application. Here, there are three Spring MVC Rest Controllers providing access points for the JSON/HTTPS API, with each controller subsequently using other components to access data from the Database and Mainframe Banking System, or send e-mails.
To zoom in to see the codes. This is an optional level of detail and is often available on-demand from tooling such as IDEs.
This is an example (and partial) UML class diagram for a fictional Internet Banking System, showing the code elements (interfaces and classes) that make up the MainframeBankingSystemFacade component. It shows that the component is made up of a number of classes, with the implementation details directly reflecting the code.
There are several subtleties of importance in regards to the c4-model. Here is a brief overview.
Type of diagram and purpose must always be included.
Short and meaningful, include the diagram type, numbered if diagram order is important; for example:
System context diagram for Financial Risk System
[System context] Financial Risk System
For example keep the colors consistent in all levels of the diagram and keep objects in the same general location for example people once placed left centre, keep them there.
Be consistent with notation and element positioning across diagrams: keeping people in the same general location for example and use the same color coding.
Shape, color and size are used to complement a diagram that already makes sense.
Be careful to use acronyms/abbreviations. It will be much easier for new people to onboard if we do not use any abbreviations but that may be to much to ask, lets at least try to avoid making Labs3/project specific abbreviations.
Start with: simple boxes containing the (A) element name, (B) type, (C) technology (if applicable) and (D) a description/responsibilities. When you make the first draft do not worry about shape and color. That will come later according to the examples above. D. is where the C4 model distinguishes itself from other architecture diagrams these descriptions will help a lot with making these diagrams useful and readable. The description can be a sentence and also 5-7 bullet points to list out the key responsibilities of that element.
c4model four types of elements image
Uni-directional lines only is preferred (arrows always point one way). Which way you point them is up to you. Usually something along the line of "thing a calls → thing b" or thing a depends on → thing b". Just make sure that the direction of the arrow matches the text on the arrow that describes it.
Most of the times when you think you need two lines for example Thing A makes an API request to —> Thing B
Thing A <— sends and API response to Thing B
Can be easy replaced by one arrow even if the direction is bidirectional, the text of the arrow makes the intent known avoiding arrow clutter. Thing A Makes API calls using —> Thing B
If there are two relationships between boxes that have completely different intents it is of course alright to show two arrows.
Every diagram needs to have one of these. Explain shapes, line styles, colours, borders, acronyms, etc... even if we have a standard and the notation seems obvious.