Apache Airflow Providers containing Deferrable Operators & Sensors from Astronomer
Project description
Apache Airflow Providers containing Deferrable Operators & Sensors from Astronomer.
Installation
Install and update using pip:
pip install astronomer-providers
This only installs dependencies for core provider. To install all dependencies, run:
pip install 'astronomer-providers[all]'
To only install the dependencies for a specific provider, specify the integration name as extra argument, example to install Kubernetes provider dependencies, run:
pip install 'astronomer-providers[cncf.kubernetes]'
Extras
Extra Name |
Installation Command |
Dependencies |
---|---|---|
all |
pip install 'astronomer-providers[all]' |
All |
amazon |
pip install 'astronomer-providers[amazon]' |
Amazon |
apache.hive |
pip install 'astronomer-providers[apache.hive]' |
Apache Hive |
apache.livy |
pip install 'astronomer-providers[apache.livy]' |
Apache Livy |
cncf.kubernetes |
pip install 'astronomer-providers[cncf.kubernetes]' |
Cncf Kubernetes |
databricks |
pip install 'astronomer-providers[databricks]' |
Databricks |
dbt.cloud |
pip install 'astronomer-providers[dbt.cloud]' |
Dbt Cloud |
pip install 'astronomer-providers[google]' |
||
http |
pip install 'astronomer-providers[http]' |
Http |
microsoft.azure |
pip install 'astronomer-providers[microsoft.azure]' |
Microsoft Azure |
openlineage |
pip install 'astronomer-providers[openlineage]' |
Openlineage |
snowflake |
pip install 'astronomer-providers[snowflake]' |
Snowflake |
Example Usage
This repo is structured same as the Apache Airflow’s source code, so for example if you want to import Async operators, you can import it as follows:
from astronomer.providers.amazon.aws.sensors.s3 import S3KeySensorAsync as S3KeySensor
waiting_for_s3_key = S3KeySensor(
task_id="waiting_for_s3_key",
bucket_key="sample_key.txt",
wildcard_match=False,
bucket_name="sample-bucket",
)
Example DAGs for each provider is within the respective provider’s folder. For example, the Kubernetes provider’s DAGs are within the astronomer/providers/cncf/kubernetes/example_dags folder.
Principle
We will only create Async operators for the “sync-version” of operators that do some level of polling (take more than a few seconds to complete).
For example, we won’t create an async Operator for a BigQueryCreateEmptyTableOperator but will create one for BigQueryInsertJobOperator that actually runs queries and can take hours in the worst case for task completion.
To create async operators, we need to inherit from the corresponding airflow sync operators. If sync version isn’t available, then inherit from airflow BaseOperator.
To create async sensors, we need to inherit from the corresponding sync sensors. If sync version isn’t available, then inherit from airflow BaseSensorOperator.
Changelog
We follow Semantic Versioning for releases. Check CHANGELOG.rst for the latest changes.
Contributing Guide
All contributions, bug reports, bug fixes, documentation improvements, enhancements, and ideas are welcome.
A detailed overview on how to contribute can be found in the Contributing Guide.
As contributors and maintainers to this project, you are expected to abide by the Contributor Code of Conduct.
Goals for the project
Our focus is on the speed of iteration and development in this stage of the project and so we want to be able to quickly iterate with our community members and customers and cut releases as necessary
Airflow Providers are separate packages from the core apache-airflow package and we would like to avoid further bloating the Airflow repo
We want users and the community to be able to easily track features and the roadmap for individual providers that we develop
We would love to see the Airflow community members create, maintain and share their providers to build an Ecosystem of Providers.
Limitations
In Airflow sensors have a param mode which can be poke and reschedule. In async sensors, this param has no usage since tasks gets deferred to Triggerer.
License
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
File details
Details for the file astronomer-providers-1.9.0.tar.gz
.
File metadata
- Download URL: astronomer-providers-1.9.0.tar.gz
- Upload date:
- Size: 137.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d7179598a0605449efc5536d908d4c8fe4fe3580ee7039f2405ee466e4c44146 |
|
MD5 | 4bdfe1a2863e37196d8d344803947b8f |
|
BLAKE2b-256 | 032dcd7d34116a8506bd6ae9e26506f3bd20928a3fe6cf6b3cb9e17bdde34e78 |
File details
Details for the file astronomer_providers-1.9.0-py3-none-any.whl
.
File metadata
- Download URL: astronomer_providers-1.9.0-py3-none-any.whl
- Upload date:
- Size: 210.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0fe1f85061b8eae7177df7a57905c69d405614c6f9100da159b40a713657be4f |
|
MD5 | 67c5a5d2a62e65de4aada8ed3d3f5618 |
|
BLAKE2b-256 | 8921d07d20e66e22f234387cddc8c8de679d70a5ccd2c5e7c534f13f34ff2cc8 |