Skip to main content

Datahub prefect block to capture executions and send to Datahub

Project description

prefect-datahub

Emit flows & tasks metadata to DataHub REST API with prefect-datahub

PyPI

Introduction

The prefect-datahub collection allows you to easily integrate DataHub's metadata ingestion capabilities into your Prefect workflows. With this collection, you can emit metadata about your flows, tasks, and workspace to DataHub's metadata service.

Features

  • Seamless integration with Prefect workflows
  • Support for ingesting metadata of flows, tasks, and workspaces to DataHub GMS REST API
  • Easy configuration using Prefect blocks

Prerequisites

  • Python 3.10+
  • Prefect 2.0.0+ and < 3.0.0+
  • A running instance of DataHub

Installation

Install prefect-datahub using pip:

pip install prefect-datahub

We recommend using a Python virtual environment manager such as pipenv, conda, or virtualenv.

Getting Started

1. Set up DataHub

Before using prefect-datahub, you need to deploy an instance of DataHub. Follow the instructions on the DataHub Quickstart page to set up DataHub.

After successful deployment, the DataHub GMS service should be running on http://localhost:8080 if deployed locally.

2. Configure DataHub Emitter

Save your DataHub configuration as a Prefect block:

from prefect_datahub.datahub_emitter import DatahubEmitter

datahub_emitter = DatahubEmitter(
    datahub_rest_url="http://localhost:8080",
    env="DEV",
    platform_instance="local_prefect",
    token=None,  # generate auth token in the datahub and provide here if gms endpoint is secure
)
datahub_emitter.save("datahub-emitter-test")

Configuration options:

Config Type Default Description
datahub_rest_url str http://localhost:8080 DataHub GMS REST URL
env str PROD Environment for assets (see FabricType)
platform_instance str None Platform instance for assets (see Platform Instances)

3. Use DataHub Emitter in Your Workflows

Here's an example of how to use the DataHub Emitter in a Prefect workflow:

from prefect import flow, task
from prefect_datahub.datahub_emitter import DatahubEmitter
from prefect_datahub.entities import Dataset

datahub_emitter_block = DatahubEmitter.load("datahub-emitter-test")

@task(name="Extract", description="Extract the data")
def extract():
    return "This is data"

@task(name="Transform", description="Transform the data")
def transform(data, datahub_emitter):
    transformed_data = data.split(" ")
    datahub_emitter.add_task(
        inputs=[Dataset("snowflake", "mydb.schema.tableX")],
        outputs=[Dataset("snowflake", "mydb.schema.tableY")],
    )
    return transformed_data

@flow(name="ETL", description="Extract transform load flow")
def etl():
    datahub_emitter = datahub_emitter_block
    data = extract()
    transformed_data = transform(data, datahub_emitter)
    datahub_emitter.emit_flow()

if __name__ == "__main__":
    etl()

Note: To emit task metadata, you must call emit_flow() at the end of your flow. Otherwise, no metadata will be emitted.

Advanced Usage

For more advanced usage and configuration options, please refer to the prefect-datahub documentation.

Contributing

We welcome contributions to prefect-datahub! Please refer to our Contributing Guidelines for more information on how to get started.

Support

If you encounter any issues or have questions, you can:

License

prefect-datahub is released under the Apache 2.0 license. See the LICENSE file for details.

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

prefect_datahub-1.6.0.9rc1.tar.gz (15.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

prefect_datahub-1.6.0.9rc1-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file prefect_datahub-1.6.0.9rc1.tar.gz.

File metadata

  • Download URL: prefect_datahub-1.6.0.9rc1.tar.gz
  • Upload date:
  • Size: 15.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for prefect_datahub-1.6.0.9rc1.tar.gz
Algorithm Hash digest
SHA256 8d0def0b7f4fc8e02027142363ad1e41a7fe95b5bf4c391c74d5a06e9b3183f8
MD5 db625c2134d5a20ef698cffe8d739788
BLAKE2b-256 249e1d0973380dc3f1575a54d9ef9d5c22b957af26998cce66a9e63d25c3b69e

See more details on using hashes here.

File details

Details for the file prefect_datahub-1.6.0.9rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for prefect_datahub-1.6.0.9rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 32dc46efc8c3ead3e142155cbb120b8e5cb1eefb802683364e5ea0c0a8c76501
MD5 6992a3afeacd5597852f3bdee5c3206b
BLAKE2b-256 6eb481333cff48e9ef7ff7e56bce0c7789bcf8d3fd3cf04e6ee3c6a382cccfbf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page