6.6 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	| title | slug | 
|---|---|
| Airflow Deployment | /deployment/airflow | 
Airflow
This section will show you how to configure your Airflow instance to run the OpenMetadata workflows.
Moreover, we will show the required steps to connect your Airflow instance to the OpenMetadata server so that you can deploy with the OpenMetadata UI directly to your instance.
- If you do not have an Airflow service up and running on your platform, we provide a custom Docker image, which already contains the OpenMetadata ingestion packages and custom Airflow APIs to deploy Workflows from the UI as well.
- If you already have Airflow up and running and want to use it for the metadata ingestion, you will need to install the ingestion modules to the host. You can find more information on how to do this in the Custom Airflow Installation section.
Custom Airflow Installation
If you already have an Airflow instance up and running, you might want to reuse it to host the metadata workflows as well. Here we will guide you on the different aspects to consider when configuring an existing Airflow.
There are three different angles here:
- Installing the ingestion modules directly on the host to enable the Airflow Lineage Backend.
- Installing connector modules on the host to run specific workflows.
- Installing the Airflow APIs to enable the workflow deployment through the UI.
Depending on what you wish to use, you might just need some of these installations. Note that the installation commands shown below need to be run in the Airflow instances.
Airflow Lineage Backend
Goals:
- Ingest DAGs and Tasks as Pipeline Entities when they run.
- Track DAG and Task status.
- Document lineage as code directly on the DAG definition and ingest it when the DAGs run.
Get the necessary information to install and extract metadata from the Lineage Backend here.
Connector Modules
Goal:
- Ingest metadata from specific sources.
The current approach we are following here is preparing the metadata ingestion DAGs as PythonOperators. This means that
the packages need to be present in the Airflow instances.
You will need to install:
pip3 install "openmetadata-ingestion[<connector-name>]"
And then run the DAG as explained in each Connector.
Airflow APIs
Note that these steps are required if you are reusing a host that already has Airflow installed.
The openmetadata-ingestion-apis has a dependency on apache-airflow>=2.2.2. Please make sure that
your host satisfies such requirement. Only installing the openmetadata-ingestion-apis won't result
in a proper full Airflow installation. For that, please follow the Airflow docs.
Goal:
- Deploy metadata ingestion workflows directly from the UI.
This process consists of three steps:
- Install the APIs module,
- Install the openmetadata-ingestionlibrary and any extras you might need, and
- Configure the OpenMetadata server.
The goal of this module is to add some HTTP endpoints that the UI calls for deploying the Airflow DAGs. The first step can be achieved by running:
pip3 install "openmetadata-managed-apis"
Then, check the Connector Modules guide above to learn how to install the openmetadata-ingestion package with the
necessary plugins. They are necessary because even if we install the APIs, the Airflow instance needs to have the
required libraries to connect to each source.
AIRFLOW_HOME
The APIs will look for the AIRFLOW_HOME environment variable to place the dynamically generated DAGs. Make
sure that the variable is set and reachable from Airflow.
Airflow APIs Basic Auth
Note that the integration of OpenMetadata with Airflow requires Basic Auth in the APIs. Make sure that your Airflow configuration supports that. You can read more about it here.
A possible approach here is to update your airflow.cfg entries with:
[api]
auth_backends = airflow.api.auth.backend.basic_auth
Configure in the OpenMetadata Server
After installing the Airflow APIs, you will need to update your OpenMetadata Server.
The OpenMetadata server takes all its configurations from a YAML file. You can find them in our repo. In
openmetadata.yaml, update the airflowConfiguration section accordingly.
[...]
airflowConfiguration:
   apiEndpoint: ${AIRFLOW_HOST:-http://localhost:8080}
   username: ${AIRFLOW_USERNAME:-admin}
   password: ${AIRFLOW_PASSWORD:-admin}
   metadataApiEndpoint: ${SERVER_HOST_API_URL:-http://localhost:8585/api}
   authProvider: ${AIRFLOW_AUTH_PROVIDER:-"no-auth"}
[...]
If using Docker, make sure that you are passing the correct environment variables:
AIRFLOW_HOST: ${AIRFLOW_HOST:-http://ingestion:8080}
SERVER_HOST_API_URL: ${SERVER_HOST_API_URL:-http://openmetadata-server:8585/api}
Validating the installation
What we need to verify here is that the OpenMetadata server can reach the Airflow APIs endpoints
(wherever they live: bare metal, containers, k8s pods...). One way to ensure that is to connect to the deployment
hosting your OpenMetadata server and running a query against the /health endpoint. For example:
$ curl -XGET ${AIRFLOW_HOST}/api/v1/openmetadata/health
{"status": "healthy", "version": "x.y.z"}
It is important to do this validation passing the command as is (i.e., curl -XGET ${AIRFLOW_HOST}/api/v1/openmetadata/health)
and allowing the environment to do the substitution for you. That's the only way we can be sure that the setup is
correct.
More validations in the installation
If you have an existing DAG in Airflow, you can further test your setup by running the following:
curl -XPOST http://localhost:8080/api/v1/openmetadata/enable --data-raw '{"dag_id": "example_bash_operator"}' -u "admin:admin" --header 'Content-Type: application/json'
Note that in this example we are assuming:
- There is an Airflow instance running at localhost:8080,
- There is a user adminwith passwordadmin
- There is a DAG named example_bash_operator.
A generic call would look like:
curl -XPOST <AIRFLOW_HOST>/api/v1/openmetadata/enable --data-raw '{"dag_id": "<DAG name>"}' -u "<user>:<password>" --header 'Content-Type: application/json'
Please update it accordingly.
