Why are there so many guides on how to set up Apache Airflow when the code could just be given to you?!
Welcome to Avionix Airflow
, an out of the box solution to installing airflow on
Kubernetes.
Currently supported platforms are Minikube and AWS EKS (managed nodegroups only), pull requests adding support for GKE and AKS are welcome.
Avionix airflow
provides the following out of the box solutions for airflow
- Airflow Webserver and Scheduler with configured RBAC for the KubernetesExecutor
- Airflow metric collection (statsd -> telegraf -> elasticsearch)
- Airflow log collection (stdout -> filebeat -> elasticsearch)
- Metric and log visualization (elasticsearch & postgres -> grafana)
pip install avionix_airflow
Avionix airflow
is configured by using Options objects, there are currently 4
different objects:
- AirflowOptions
- PostgresOptions
- MonitoringOptions
- CloudOptions (Specified using LocalOptions or AwsOptions)
- RedisOptions (Only for use with CeleryExecutor, *not recommended*)
These options are then passed into the function get_chart_builder, which can be used to retrieve an avionix chart builder object. For instruction on how to use the builder object, see avionix
- How do I change the grafana dashboard?
- You can change the dashboard by setting the MonitoringOptions role to "Admin"
Additional documentation can be found here