This manual does not specify, and is not concerned with, the question of how your organization organizes its code and docs into one, a few, or many different repositories — only that all of your diagrams should live together in the same repo.
There can be lots of other files in the same repo, or you could dedicate a repo to host only your diagrams — it’s your call.
Some users of the tool host their diagrams in a docs
repo that hosts cross-domain,
cross-system, or cross-team documentation. In such a case the diagrams might be in a root-level dir
with an imaginative name such as diagrams
.
You may be wondering why the rendered image files are committed to the repo, rather than considered akin to deployment artifacts that can always be regenerated from the diagram source files, and might therefore be reasonably considered outside of the set of content that it’s important or advisable to store in a source control system.
Indeed, storing these files in the repository does tend to balloon the storage size of the repository; a repository storing only the source for 100 diagrams might be ~10 MB, whereas a repository storing the source and images for 100 diagrams might be 100 MB or more.
Despite the downsides, it’s still worthwhile to store the images in the repository. The main reason is that doing so enables seeing the changes made to the diagrams, graphically, via image diffing features of e.g. GitHub and possibly other git hosting services. This can make peer review drastically more effective.
If you prefer to keep your Git repositories svelte, Git Large File Storage (LFS) works well with these recommendations.
diagrams
diagrams
dataflow
, workflow
, etc.
Here are some recommendations for file names:
Diagram | Recommended File Name Mask |
---|---|
System Landscape | {landscape}_system_landscape.{yaml|png} |
System Context | {system}_01_context.{yaml|png} |
Container | {system}_02_container.{yaml|png} |
Intra-System Dynamic | {system}_03_{dataflow|workflow}.{yaml|png} |
Inter-System Dynamic | {case}_{dataflow|workflow}.{yaml|png} |
{org}_
{landscape}_
— after the {org}_
prefix, if present$ tree diagrams
diagrams
└── fc4
├── README.md
├── some_app
│ ├── some_app_01_system_context.png
│ ├── some_app_01_system_context.yaml
│ ├── some_app_02_container.png
│ └── some_app_02_container.yaml
│ └── some_app_03_dataflow.png
│ └── some_app_03_dataflow.yaml
├── system_landscape.png
└── system_landscape.yaml
fc4
level in the above hierarchy is optional.$ tree diagrams
diagrams
└── fc4
├── README.md
├── some_landscape
├── some_other_landscape
├── third_landscape
│ ├── some_app
│ │ ├── some_app_01_system_context.png
│ │ ├── some_app_01_system_context.yaml
│ │ ├── some_app_02_container.png
│ │ └── some_app_02_container.yaml
│ │ ├── some_app_03_dataflow.png
│ │ └── some_app_03_dataflow.yaml
│ ├── third_landscape_system_landscape.png
│ └── third_landscape_system_landscape.yaml
└── us
fc4
level in the above hierarchy is optional.Please continue to The Authoring Workflow or go back to the top page of the manual.