Auto-generated Diagrams from Airflow DAGs.
Project description
airflow-diagrams
Auto-generated Diagrams from Airflow DAGs.
This project aims to easily visualise your Airflow DAGs on service level from providers like AWS, GCP, Azure, etc. via diagrams.
🚀 Get started
To install it from PyPI run:
pip install airflow-diagrams
Then just call it like this:
Usage: airflow-diagrams generate [OPTIONS]
Generates <airflow-dag-id>_diagrams.py in <output-path> directory which
contains the definition to create a diagram. Run this file and you will get
a rendered diagram.
Options:
-d, --airflow-dag-id TEXT The dag id from which to generate the diagram.
By default it generates for all.
-h, --airflow-host TEXT The host of the airflow rest api from where to
retrieve the dag tasks information. [default:
http://localhost:8080/api/v1]
-u, --airflow-username TEXT The username of the airflow rest api.
[default: admin]
-p, --airflow-password TEXT The password of the airflow rest api.
[default: admin]
-o, --output-path DIRECTORY The path to output the diagrams to. [default:
.]
-m, --mapping-file FILE The mapping file to use for static mapping from
Airflow task to diagram node. By default no
mapping file is being used.
-v, --verbose Verbose output i.e. useful for debugging
purposes.
--help Show this message and exit.
Examples of generated diagrams can be found in the examples directory.
🤔 How it Works
ℹ️ At first it connects, by using the official Apache Airflow Python Client, to your Airflow installation to retrieve all DAGs (in case you don't specify any dag_id
) and all Tasks for the DAG(s).
🔮 Then it tries to find a diagram node for every DAGs task, by using Fuzzy String Matching, that matches the most. If you are unhappy about the match you can also provide a mapping.yml
file to statically map from Airflow task to diagram node.
🪄 Lastly it renders the results into a python file which can then be executed to retrieve the rendered diagram. 🎉
❤️ Contributing
Contributions are very welcome. Please go ahead and raise an issue if you have one or open a PR. Thank you.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for airflow_diagrams-1.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | da8b4c086905c67bbf05f65bee74fef9078a093c910a892cbb1fcc7806f9078e |
|
MD5 | 8436d8bd7ff784618d40fe0c7ba77f9e |
|
BLAKE2b-256 | 1067f112a4e197ba5f7c68d695ee8b2b9bf871033eef4d24ab76a99468a42d63 |