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.
 
 
 
 
 
Bruno Meneguello d3ee0b66bc Fix node attrs not being copied to Cluster 3 年之前
.github Setup dependabot. (#387) 4 年之前
assets/img fix: resize logo 4 年之前
diagrams Fix node attrs not being copied to Cluster 3 年之前
docker/dev feat(docker): Add support for CJK fonts + Replace ms-fonts with opensans. (#242) 4 年之前
docs Allow nodes to be user as cluster 3 年之前
examples Azure base clusters 3 年之前
resources feat(node): added nextcloud, bitwarden, boundary and ambassador (#363) 4 年之前
scripts feat(nodes): pve lxc java dns zabbix (#291) 4 年之前
templates feat: docs auto generation 4 年之前
tests chore: clean styles 4 年之前
website chore(deps-dev): bump docusaurus from 1.14.4 to 1.14.6 in /website (#397) 4 年之前
.gitignore Add programming languages and frameworks (#112) 4 年之前
CHANGELOG.md docs(changelog): update PR links 4 年之前
CONTRIBUTING.md docs(contributing): trying to ease the flow for newcomers (#286) 4 年之前
DEVELOPMENT.md docs(contributing): trying to ease the flow for newcomers (#286) 4 年之前
LICENSE license: create LICENSE.md 4 年之前
README.md docs(readme): New GitPitch 4.0 Diagrams-as-Code Widget doc link. (#328) 4 年之前
autogen.sh add outscale provider (#251) 4 年之前
config.py fix: onprem storage incorrect config (#345) 4 年之前
poetry.lock chore: update black 4 年之前
pyproject.toml bump: up to version 0.18.0 4 年之前

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 openstack provider firebase provider outscale provider elastic provider generic provider programming provider saas 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 uses it?

GitPitch

GitPitch is the perfect slide deck solution for Tech Conferences, Training, Developer Advocates, and Educators. Diagrams is now available as a dedicated Cloud Diagram Markdown Widget so you can use Diagrams directly on any slide for conferences, meetups, and training.

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 infrastructure with Cloudicovery.

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 to Go, you can use go-diagrams as well.

License

MIT