You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Thomas Senay e7e492534e
Merge c3a8ad8d38 into 4ce9e6f615
2 週之前
.github Update version of codeql-analysis.yml (#1035) 2 週之前
assets/img fix: resize logo 4 年之前
diagrams Merge c3a8ad8d3843c94cdd7bdf8ff71d312b7a3d2bff into 4ce9e6f6156a2b3489a4c7d6520fce576ba3e136 2 週之前
docker/dev chore: fixing go get deprecation (#713) 2 年之前
docs Merge branch 'master' into master 3 週之前
resources Merge pull request #1032 from mingrammer/1031-feature-request-add-sonarqube-logo 2 週之前
scripts Improve wording of documentation (#990) 7 月之前
templates Improve wording of documentation (#990) 7 月之前
tests fix(tests): set lower for case sensitive system (#805) 1 年之前
website Merge pull request #1032 from mingrammer/1031-feature-request-add-sonarqube-logo 2 週之前
.gitignore Add programming languages and frameworks (#112) 4 年之前
CHANGELOG.md fix: Add breaking changes to Changelog 1 月之前
CONTRIBUTING.md Improve wording of documentation (#990) 7 月之前
DEVELOPMENT.md Issue-1009: update 1 月之前
LICENSE license: create LICENSE.md 4 年之前
README.md fix: Refactor on-premises service names for consistency 1 月之前
autogen.sh style: split the provider list by newline 2 年之前
config.py feat(node): add vercel + fix alias 3 週之前
poetry.lock Issue 1009: update poetry.lock 1 月之前
pyproject.toml bump: up to version 0.24.0 2 週之前

README.md

diagrams logo

Diagrams

license pypi version python version Run tests todos contributors

Buy Me A Coffee

Diagram as Code.

Diagrams lets you draw the cloud system architecture in Python code. It was born for prototyping a new system architecture design without any design tools. You can also describe or visualize the existing system architecture as well. Diagrams currently supports main major providers including: AWS, Azure, GCP, Kubernetes, Alibaba Cloud, Oracle Cloud etc... It also supports On-Premises nodes, SaaS and major Programming frameworks and languages.

Diagram as Code also allows you to track the architecture diagram changes in any version control system.

NOTE: It does not control any actual cloud resources nor does it generate cloud formation or terraform code. It is just for drawing the cloud system architecture diagrams.

Providers

aws provider azure provider gcp provider ibm provider kubernetes provider alibaba cloud provider oracle cloud provider openstack provider firebase provider digital ocean provider elastic provider outscale provider on premises provider generic provider programming provider saas provider c4 provider

Getting Started

It requires Python 3.7 or higher, check your Python version first.

It uses Graphviz to render the diagram, so you need to install Graphviz to use diagrams. After installing graphviz (or already have it), install the diagrams.

macOS users can download the Graphviz via brew install graphviz if you’re using Homebrew.

# using pip (pip3)
$ pip install diagrams

# using pipenv
$ pipenv install diagrams

# using poetry
$ poetry add diagrams

You can start with quick start. Check out guides for more details, and you can find all available nodes list in here.

Examples

Event Processing Stateful Architecture Advanced Web Service
event processing stateful architecture advanced web service with on-premises

You can find all the examples on the examples page.

Contributing

To contribute to diagram, check out contribution guidelines.

Let me know if you are using diagrams! I’ll add you in showcase page. (I’m working on it!) :)

Who uses it?

Apache Airflow is the most popular data workflow Orchestrator. Airflow uses Diagrams to generate architecture diagrams in their documentation.

Cloudiscovery helps you to analyze resources in your cloud (AWS/GCP/Azure/Alibaba/IBM) account. It allows you to create a diagram of analyzed cloud resource map based on this Diagrams library, so you can draw your existing cloud infrastructure with Cloudiscovery.

Airflow Diagrams is an Airflow plugin that aims to easily visualise your Airflow DAGs on service level from providers like AWS, GCP, Azure, etc. via diagrams.

Other languages

  • If you are familiar with Go, you can use go-diagrams as well.

License

MIT