Machine Learning Orchestration
Project description
Overview
The dbnd-mlflow plugin allows storing mlflow metrics to DBND tracker together with duplicating them to the mlflow store.
Install
pip install dbnd-mlflow
# or
pip install databand[mlflow]
Config
[core]
# Databand store url should be defined
databand_url=http://localhost:8080
[mlflow_tracking]
# Enable tracking to Databand store
databand_tracking=True
# Optionally, define a URI for mlflow store,
# mlflow.get_tracking_uri() is used by default
; duplicate_tracking_to=http://mlflow-store/
Run example
You might need to install examples at first pip install dbnd-examples.
dbnd run dbnd_examples.mlflow_.run_mlflow_in_dbnd_task.mlflow_tracking_in_task_example
# or set configs manually
dbnd run dbnd_examples.mlflow_.run_mlflow_in_dbnd_task.mlflow_tracking_in_task_example --set-config mlflow_tracking.databand_tracking=True
Explanation
mlflow_example code
from dbnd import task
from mlflow import start_run, end_run
from mlflow import log_metric, log_param
@task
def mlflow_example():
start_run()
# params
log_param("param1", randint(0, 100))
log_param("param2", randint(0, 100))
# metrics
log_metric("foo1", random())
log_metric("foo2", random())
end_run()
Execution flow:
- Run
dbnd run mlflow_example --set-config mlflow_tracking.databand_tracking=True - dbnd creates a new dbnd context
dbnd_on_pre_init_contexthook fromdbnd_mlflowis triggered- a new uri is computed to be used by mlflow, e.g.:
dbnd://localhost:8080?duplicate_tracking_to=http%253A%252F%252Fmlflow-store%253A80%252F
- the new uri is set to be used with
mlflow.set_tracking_uri()
- a new uri is computed to be used by mlflow, e.g.:
mlflow_exampletask starts:mlflow.start_run()mlflowreadsentry_pointsfor each installed package and finds:- "dbnd = dbnd_mlflow.tracking_store:get_dbnd_store",
- "dbnd+s = dbnd_mlflow.tracking_store:get_dbnd_store",
- "databand = dbnd_mlflow.tracking_store:get_dbnd_store",
- "databand+s = dbnd_mlflow.tracking_store:get_dbnd_store",
mlflowcreatesTrackingStoreClientusing the new uri- uri schema instructs to use
dbnd_mlflow.tracking_store:get_dbnd_storeget_dbnd_storecreates dbndTrackingAPIClientget_dbnd_storecreates mlflow tracking store to duplicate tracking toget_dbnd_storereturnsDatabandStoreinstance
log_param()/log_metric()- calls to
DatabandStore- calls to
TrackingAPIClient - calls to mlflow tracking store to duplicate tracking to
- calls to
- calls to
mlflow.end_run()
mlflow_exampleendsdbnd_on_exit_contexthook fromdbnd_mlflowis triggered- restore original mlflow tracking uri
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
dbnd-mlflow-0.36.0.tar.gz
(10.7 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dbnd-mlflow-0.36.0.tar.gz.
File metadata
- Download URL: dbnd-mlflow-0.36.0.tar.gz
- Upload date:
- Size: 10.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.6.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
79d133daf1ef104e7ede56eaa802004f2ff20fb4195d4a1e56213ab6c89918c0
|
|
| MD5 |
e2017d8b4d3263005f5d142d48fae883
|
|
| BLAKE2b-256 |
45111edba0471e09a50c0e78e51b883bfe055465ff234f8033aa998d47c6bddf
|
File details
Details for the file dbnd_mlflow-0.36.0-py2.py3-none-any.whl.
File metadata
- Download URL: dbnd_mlflow-0.36.0-py2.py3-none-any.whl
- Upload date:
- Size: 10.8 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.6.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d2903ba5f5cb4589251dd77d664d5c3e2402985d7ca5480fc47013e9c48b7d74
|
|
| MD5 |
2301bc9abe77460ac0c156d8218b1c22
|
|
| BLAKE2b-256 |
aa9356002a416fab5251a4b046314725f69dbc5a2f86b04a46cdc5879ca67028
|