OpenLineage Python Client
Project description
OpenLineage-python
To install from source, run:
$ python setup.py install
Configuration
Config file
The most common way to configure the OpenLineage Client is by .yaml
file, which contains all the
details of how to connect to your OpenLineage backend.
The config file is located by:
- looking at the
OPENLINEAGE_CONFIG
environment variable - looking for the
openlineage.yml
file in the current working directory - looking for the
openlineage.yml
file in the$HOME/.openlineage
directory.
Different ways of connecting to OpenLineage backend are supported
by the standarized Transport
interface.
This is an example config for specifying http
transport:
transport:
type: "http"
url: "https://backend:5000"
auth:
type: "api_key"
api_key: "f048521b-dfe8-47cd-9c65-0cb07d57591e"
The type
property is required. It can be one of the built-in transports or a custom one.
There are three built-in transports, http
, kafka
and console
.
Custom transports type
is a fully qualified class name that can be imported.
The rest of the properties are defined by the particular transport.
Specifications for the built-in options are below.
HTTP
url
- required string parameter.endpoint
- optional string parameter specifying the endpoint to which events are sent. By defaultapi/v1/lineage
.timeout
- optional float parameter specifying the timeout when sending events. By default 5 seconds.verify
optional boolean attribute specifying if the client should verify TLS certificates of the backend. By default true.auth
- optional dictionary specifying authentication options. The type property is required.type
: required property if an auth dictionary is set. Set toapi_key
or to the fully qualified class name of your TokenProvider.api_key
: ifapi_key
type is set, it sets value atAuthentication
HTTP header asBearer
.
Kafka
config
- required string parameter. A dictionary that contains a Kafka producer config as in Kafka producer config.topic
- required string parameter. The topic on what events will be sent.flush
- optional boolean parameter. If set to True, Kafka will flush after each event. By default true.
Custom transport
To implement a custom transport, follow the instructions in the openlineage/client/transport/transport.py
file.
Config as env vars
If there is no config file found, the OpenLineage client looks at environment variables.
This way of configuring the client supports only http
transport, and only a subset of its config.
OPENLINEAGE_URL
- point to the service that will consume OpenLineage events.OPENLINEAGE_API_KEY
- set if the consumer of OpenLineage events requires aBearer
authentication key.
OPENLINEAGE_URL
and OPENLINEAGE_API_KEY
can also be set up manually when creating a client instance.
SPDX-License-Identifier: Apache-2.0
Copyright 2018-2022 contributors to the OpenLineage project
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 openlineage-python-0.18.0.tar.gz
.
File metadata
- Download URL: openlineage-python-0.18.0.tar.gz
- Upload date:
- Size: 11.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.7.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 794484037af76cca35beb2955d64da1135bd5dfaa7af95ed6ad56e8756c45002 |
|
MD5 | 79dfbdea977afcfc746ad03b995c1bcf |
|
BLAKE2b-256 | 535e03e4dd696a6756efed3eb1995bdcf64c83d43b66a65973db49ae2f4651c1 |
File details
Details for the file openlineage_python-0.18.0-py3-none-any.whl
.
File metadata
- Download URL: openlineage_python-0.18.0-py3-none-any.whl
- Upload date:
- Size: 15.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.7.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f162358123a57065032f77fcb2c9a1f421d7137e75ec943124925a497f5e946c |
|
MD5 | b51b9d587b6496043c43c11b645aa3fe |
|
BLAKE2b-256 | 750fd1807d2d89de2ebd96b777d3019f5e7a9597e1530950f0d7b2bac3cd09fa |