🎨 Diagram as Code for prototyping cloud system architectures
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.
 
 
 
 
 
Go to file
gabriel-tessier 17e4e73495
feat(docker): Add support for CJK fonts + Replace ms-fonts with opensans. (#242)
4 years ago
.github/workflows ci: install graphviz 5 years ago
assets/img
diagrams feat(node): add saas.alerting.Pushover (#241) 4 years ago
docker/dev feat(docker): Add support for CJK fonts + Replace ms-fonts with opensans. (#242) 4 years ago
docs feat(node): add saas.alerting.Pushover (#241) 4 years ago
resources feat(node): add saas.alerting.Pushover (#241) 4 years ago
scripts feat(node): update all OCI nodes 4 years ago
templates
tests fix(diagrams): Set a dummy filename to prevent raise error when both … (#240) 4 years ago
website chore(deps): bump lodash from 4.17.15 to 4.17.19 in /website (#238) 4 years ago
.gitignore
CHANGELOG.md docs(changelog): add oci nodes changes (#236) (#239) 4 years ago
CONTRIBUTING.md
DEVELOPMENT.md Docker local development setup (#210) 4 years ago
LICENSE
README.md #15 Add Openstack as cloud provider (#211) 4 years ago
autogen.sh #15 Add Openstack as cloud provider (#211) 4 years ago
config.py fix(scripts): update inkscape option 4 years ago
poetry.lock
pyproject.toml bump: up to version 0.16.0 4 years ago

README.md

diagrams logo

Diagrams

license pypi version python version Run tests todos

on premise provider aws provider azure provider gcp provider kubernetes provider alibaba cloud provider oracle cloud provider programming provider firebase provider elastic provider saas provider openstack provider

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-Premise 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.

Getting Started

It requires Python 3.6 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-premise

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 use it?

GitPitch

GitPitch is a markdown presentation service for developers. Diagrams is now integrated as Cloud Diagram Widget of GitPitch, so you can use the Diagrams when to create slide decks for Tech Conferences, Meetups, and Training with GitPitch.

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 the your existing cloud infratructure with Cloudicovery.

License

MIT