Skip to content

Latest commit

 

History

History
78 lines (63 loc) · 3.17 KB

README.md

File metadata and controls

78 lines (63 loc) · 3.17 KB

AirFlow on Huawei Cloud CCE

This repository contains the files and instructions required to deploy AirFlow in a Huawei Cloud Container Engine (CCE) cluster, using the official AirFlow Helm Chart.

Requirements

Installation

  1. Create two Parallel File Systems, one for DAGs and other for logs;
  2. Create an IAM User with programmatic access (do not assign to any group) and download the credentials file (with AK/SK);
  3. In both PFS, create a policy that allows bucket read/write only for the IAM User created previously;
  4. Apply base64 encoding to AK and to SK;
  5. Update obs-airflow.yml with AK and SK encoded, and also with PFS names and Enterprise Project ID;
  6. Create the namespace and the PV/PVCs for PFS:
kubectl apply -f airflow-namespace.yml
kubectl apply -f obs-airflow.yml
  1. This repository uses a separate container for PostgreSQL. Generate a random password, update the POSTGRES_PASSWORD value in postgresql-workload.yml and data.metadataConnection.pass in values.yml;
  2. Create the PostgreSQL Workload:
kubectl apply -f postgresql-workload.yml
  1. Generate a new password for the Airflow web interface, and a random value for webserverSecretKey and update values.yml;
  2. Install the Helm chart in the CCE Cluster:
helm repo add apache-airflow https://airflow.apache.org
helm upgrade --install airflow apache-airflow/airflow --namespace airflow -f values.yml
  1. Create an ingress to access the AirFlow web interface, or update the airflow-webserver service to be NodePort or DNAT instead. If you choose to create an ingress, you can use the CCE console to create an ELB Ingress. If you choose NodePort, make sure the CCE Node has an EIP bound. If you choose DNAT, create a public NAT Gateway first and then use the CCE console to create a DNAT rule.

Uninstall

helm delete airflow --namespace airflow
kubectl delete pvc -n airflow redis-db-airflow-redis-0
kubectl delete pvc -n airflow data-airflow-postgresql-0
kubectl delete -f postgresql-workload.yml
kubectl delete -f obs-airflow.yml
kubectl delete -f airflow-namespace.yml