comet-for-mlflow


Namecomet-for-mlflow JSON
Version 0.1.5 PyPI version JSON
download
home_pagehttps://github.com/comet-ml/comet-for-mlflow
SummaryExtend MLFlow with Comet.ml
upload_time2023-11-17 13:11:49
maintainer
docs_urlNone
authorBoris Feld
requires_python>=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*
licenseGNU General Public License v3
keywords comet_for_mlflow
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Comet-For-MLFlow Extension

[![image](https://img.shields.io/pypi/v/comet-for-mlflow.svg)](https://pypi.org/project/comet-for-mlflow/)
[![CI Build](https://github.com/comet-ml/comet-for-mlflow/workflows/CI%20Build/badge.svg)](https://github.com/comet-ml/comet-for-mlflow/actions) [![Updates](https://pyup.io/repos/github/comet-ml/comet-for-mlflow/shield.svg)](https://pyup.io/repos/github/comet-ml/comet-for-mlflow/)


The Comet-For-MLFlow extension is a CLI that maps MLFlow experiment runs to Comet experiments. This extension allows you to see your existing experiments in the Comet.ml UI which provides authenticated access to experiment results, dramatically improves the performance for high volume experiment runs, and provides richer charting and visualization options.

This extension will synchronize previous MLFlow experiment runs with all runs tracked with [Comet's Python SDK with MLFlow support](https://www.comet.com/docs/v2/integrations/ml-frameworks/mlflow/), for deeper experiment instrumentation and improved logging, visibility, project organization and access management.

The Comet-For-MLFlow Extension is available as free open-source software, released under GNU General Public License v3. The extension can be used with existing Comet.ml accounts or with a new, free Individual account.

# Installation

```bash
pip install comet-for-mlflow
```

If you install `comet-for-mlflow` in a different Python environment than the one you used to generate mlflow runs, please ensure that you use the same mlflow version in both environments.

# Basic usage

For automatically synchronizing MLFlow runs in their default storage location (`./mlruns`) with Comet.ml, run:

```bash
comet_for_mlflow --api-key $COMET_API_KEY --rest-api-key $COMET_REST_API_KEY
```

If you'd like to review the mapping of MLFlow runs in their default storage location without synchronizing them with Comet.ml automatically, you can run:


```bash
comet_for_mlflow --no-upload
```

After review, you can upload the mapped MLFlow runs with:

```bash
comet upload /path/to/archive.zip
```

# Example

```
 __   __         ___ ___     ___  __   __                 ___       __
/  ` /  \  |\/| |__   |  __ |__  /  \ |__) __  |\/| |    |__  |    /  \ |  |
\__, \__/  |  | |___  |     |    \__/ |  \     |  | |___ |    |___ \__/ |/\|


Please create a free Comet account with your email.
Email: kristen.stewart@example.com

Please enter a username for your new account.
Username: kstewart

A Comet.ml account has been created for you and an email was sent to you to setup your password later.
Your Comet API Key has been saved to ~/.comet.ini, it is also available on your Comet.ml dashboard.
Starting Comet Extension for MLFlow

Preparing data locally from: '/home/ks/project/mlruns'
You will have an opportunity to review.

# Preparing experiment 1/3: Default

# Preparing experiment 2/3: Keras Experiment
## Preparing run 1/4 [2e02df92025044669701ed6e6dd300ca]
## Preparing run 2/4 [93fb285da7cf4c4a93e279ab7ff19fc5]
## Preparing run 3/4 [2e8a1aed22544549b2b6b6b2c5976ed9]
## Preparing run 4/4 [82f584bad7604289af61bc505935599b]

# Preparing experiment 3/3: Tensorflow Keras Experiment
## Preparing run 1/2 [99550a7ce4c24677aeb6a1ae4e7444cb]
## Preparing run 2/2 [88ca5c4262f44176b576b54e0b24731a]

 MLFlow name:   | Comet.ml name:   |   Prepared count:
----------------+------------------+-------------------
 Experiments    | Projects         |                 3
 Runs           | Experiments      |                 6
 Tags           | Others           |                39
 Parameters     | Parameters       |                51
 Metrics        | Metrics          |                60
 Artifacts      | Assets           |                27

All prepared data has been saved to: /tmp/tmpjj74z8bf

Upload prepared data to Comet.ml? [y/N] y

# Start uploading data to Comet.ml
100%|███████████████████████████████████████████████████████████████████████| 6/6 [01:00<00:00, 15s/it]
Explore your experiment data on Comet.ml with the following links:
	- https://www.comet.ml/kstewart/mlflow-default-2bacc9?loginToken=NjKgD6f9ZuZWeudP76sDPHx9j
	- https://www.comet.ml/kstewart/mlflow-keras-experiment-2bacc9?loginToken=NjKgD6f9ZuZWeudP76sDPHx9j
	- https://www.comet.ml/kstewart/mlflow-tensorflow-keras-experiment-2bacc9?loginToken=NjKgD6f9ZuZWeudP76sDPHx9j
Get deeper instrumentation by adding Comet SDK to your project: https://comet.ml/docs/python-sdk/mlflow/


If you need support, you can contact us at http://chat.comet.ml/ or https://comet.ml/docs/quick-start/#getting-support
```


# Advanced use

## Importing MLFlow runs in a database store or in the MLFLow server store

If your MLFlow runs are not located in the default local store (`./mlruns`), you can either set the CLI flag `--mlflow-store-uri` or the environment variable `MLFLOW_TRACKING_URI` to point to the right store.

For example, with a different local store path:

```bash
comet_for_mlflow --mlflow-store-uri /data/mlruns/
```

With a SQL store:

```bash
comet_for_mlflow --mlflow-store-uri sqlite:///path/to/file.db
```

Or with a MLFlow server:

```bash
comet_for_mlflow --mlflow-store-uri http://localhost:5000
```

## Importing MLFlow artifacts stored remotely

If your MLFlow runs have artifacts stored remotely (in any of supported remote artifact stores https://www.mlflow.org/docs/latest/tracking.html#artifact-stores), you need to configure your environment the same way as when you ran those experiments. For example, with a local Minio server:

```bash
env MLFLOW_S3_ENDPOINT_URL=http://localhost:9001 \
    AWS_ACCESS_KEY_ID=minio \
    AWS_SECRET_ACCESS_KEY=minio123 \
    comet_for_mlflow
```

# FAQ

## How can I configure my API Key or Rest API Key?

You can either pass your Comet.ml API Key or Rest API Key as command-line flags or through the [usual configuration options](https://www.comet.com/docs/v2/api-and-sdk/python-sdk/advanced/configuration/).

## How are MLFlow experiments mapped to Comet.ml projects?

Each MLFlow experiment is mapped to a unique Comet.ml project ID. This way even if you rename the Comet.ml project or the MLFlow experiment, new runs will be imported in the correct Comet.ml project. The name for newly created Comet.ml is `mlflow-$MLFLOW_EXPERIMENT_NAME`. The original MLFlow experiment name is also saved as an Other field named `mlflow.experimentName`.

Below is a complete list of MLFlow experiment and run fields mapped to Comet.ml equivalent concepts:

* MLFlow Experiments are mapped as Comet.ml projects
* MLFlow Runs are mapped as Comet.ml experiments
* MLFlow Runs fields are imported according to following table:

| MLFlow Run Field 	| Comet.ml Experiment Field 	|
|------------------	|---------------------------	|
| File name        	| File name                 	|
| Tags             	| Others                    	|
| User             	| Git User + System User    	|
| Git parent       	| Git parent                	|
| Git origin       	| Git Origin                	|
| Params           	| Params                    	|
| Metrics          	| Metrics                   	|
| Artifacts        	| Assets                    	|

## Do I have to run this for future experiments?

No, the common pattern is to import [Comet's Python SDK with MLFlow support](https://www.comet.com/docs/v2/integrations/ml-frameworks/mlflow/) in your MLFlow projects, which will keep all future experiment runs synchronized.


# Credits

This package was created with [Cookiecutter](https://github.com/audreyr/cookiecutter) and the [audreyr/cookiecutter-pypackage](https://github.com/audreyr/cookiecutter-pypackage) project template.


Release History
===============

0.1.3 (2022-12-08)
------------------

- Fix compatibility with MLFlow v2.0.1 #3

0.1.2 (2020-03-12)
------------------

- Fix compatibility with Comet Python SDK v3.1.1. #2
- Fix support for unicode project notes in Python 2. #1

0.1.1 (2020-02-17)
------------------

-   Fix package URL in metadata.

0.1.0 (2020-02-12)
------------------

-   First release on PyPI.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/comet-ml/comet-for-mlflow",
    "name": "comet-for-mlflow",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*",
    "maintainer_email": "",
    "keywords": "comet_for_mlflow",
    "author": "Boris Feld",
    "author_email": "boris@comet.ml",
    "download_url": "https://files.pythonhosted.org/packages/16/9e/5b230f8a0dc66be73a40faa81fae08118cdc198f95f81cd34cde4470e895/comet_for_mlflow-0.1.5.tar.gz",
    "platform": null,
    "description": "# Comet-For-MLFlow Extension\n\n[![image](https://img.shields.io/pypi/v/comet-for-mlflow.svg)](https://pypi.org/project/comet-for-mlflow/)\n[![CI Build](https://github.com/comet-ml/comet-for-mlflow/workflows/CI%20Build/badge.svg)](https://github.com/comet-ml/comet-for-mlflow/actions) [![Updates](https://pyup.io/repos/github/comet-ml/comet-for-mlflow/shield.svg)](https://pyup.io/repos/github/comet-ml/comet-for-mlflow/)\n\n\nThe Comet-For-MLFlow extension is a CLI that maps MLFlow experiment runs to Comet experiments. This extension allows you to see your existing experiments in the Comet.ml UI which provides authenticated access to experiment results, dramatically improves the performance for high volume experiment runs, and provides richer charting and visualization options.\n\nThis extension will synchronize previous MLFlow experiment runs with all runs tracked with [Comet's Python SDK with MLFlow support](https://www.comet.com/docs/v2/integrations/ml-frameworks/mlflow/), for deeper experiment instrumentation and improved logging, visibility, project organization and access management.\n\nThe Comet-For-MLFlow Extension is available as free open-source software, released under GNU General Public License v3. The extension can be used with existing Comet.ml accounts or with a new, free Individual account.\n\n# Installation\n\n```bash\npip install comet-for-mlflow\n```\n\nIf you install `comet-for-mlflow` in a different Python environment than the one you used to generate mlflow runs, please ensure that you use the same mlflow version in both environments.\n\n# Basic usage\n\nFor automatically synchronizing MLFlow runs in their default storage location (`./mlruns`) with Comet.ml, run:\n\n```bash\ncomet_for_mlflow --api-key $COMET_API_KEY --rest-api-key $COMET_REST_API_KEY\n```\n\nIf you'd like to review the mapping of MLFlow runs in their default storage location without synchronizing them with Comet.ml automatically, you can run:\n\n\n```bash\ncomet_for_mlflow --no-upload\n```\n\nAfter review, you can upload the mapped MLFlow runs with:\n\n```bash\ncomet upload /path/to/archive.zip\n```\n\n# Example\n\n```\n __   __         ___ ___     ___  __   __                 ___       __\n/  ` /  \\  |\\/| |__   |  __ |__  /  \\ |__) __  |\\/| |    |__  |    /  \\ |  |\n\\__, \\__/  |  | |___  |     |    \\__/ |  \\     |  | |___ |    |___ \\__/ |/\\|\n\n\nPlease create a free Comet account with your email.\nEmail: kristen.stewart@example.com\n\nPlease enter a username for your new account.\nUsername: kstewart\n\nA Comet.ml account has been created for you and an email was sent to you to setup your password later.\nYour Comet API Key has been saved to ~/.comet.ini, it is also available on your Comet.ml dashboard.\nStarting Comet Extension for MLFlow\n\nPreparing data locally from: '/home/ks/project/mlruns'\nYou will have an opportunity to review.\n\n# Preparing experiment 1/3: Default\n\n# Preparing experiment 2/3: Keras Experiment\n## Preparing run 1/4 [2e02df92025044669701ed6e6dd300ca]\n## Preparing run 2/4 [93fb285da7cf4c4a93e279ab7ff19fc5]\n## Preparing run 3/4 [2e8a1aed22544549b2b6b6b2c5976ed9]\n## Preparing run 4/4 [82f584bad7604289af61bc505935599b]\n\n# Preparing experiment 3/3: Tensorflow Keras Experiment\n## Preparing run 1/2 [99550a7ce4c24677aeb6a1ae4e7444cb]\n## Preparing run 2/2 [88ca5c4262f44176b576b54e0b24731a]\n\n MLFlow name:   | Comet.ml name:   |   Prepared count:\n----------------+------------------+-------------------\n Experiments    | Projects         |                 3\n Runs           | Experiments      |                 6\n Tags           | Others           |                39\n Parameters     | Parameters       |                51\n Metrics        | Metrics          |                60\n Artifacts      | Assets           |                27\n\nAll prepared data has been saved to: /tmp/tmpjj74z8bf\n\nUpload prepared data to Comet.ml? [y/N] y\n\n# Start uploading data to Comet.ml\n100%|\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588| 6/6 [01:00<00:00, 15s/it]\nExplore your experiment data on Comet.ml with the following links:\n\t- https://www.comet.ml/kstewart/mlflow-default-2bacc9?loginToken=NjKgD6f9ZuZWeudP76sDPHx9j\n\t- https://www.comet.ml/kstewart/mlflow-keras-experiment-2bacc9?loginToken=NjKgD6f9ZuZWeudP76sDPHx9j\n\t- https://www.comet.ml/kstewart/mlflow-tensorflow-keras-experiment-2bacc9?loginToken=NjKgD6f9ZuZWeudP76sDPHx9j\nGet deeper instrumentation by adding Comet SDK to your project: https://comet.ml/docs/python-sdk/mlflow/\n\n\nIf you need support, you can contact us at http://chat.comet.ml/ or https://comet.ml/docs/quick-start/#getting-support\n```\n\n\n# Advanced use\n\n## Importing MLFlow runs in a database store or in the MLFLow server store\n\nIf your MLFlow runs are not located in the default local store (`./mlruns`), you can either set the CLI flag `--mlflow-store-uri` or the environment variable `MLFLOW_TRACKING_URI` to point to the right store.\n\nFor example, with a different local store path:\n\n```bash\ncomet_for_mlflow --mlflow-store-uri /data/mlruns/\n```\n\nWith a SQL store:\n\n```bash\ncomet_for_mlflow --mlflow-store-uri sqlite:///path/to/file.db\n```\n\nOr with a MLFlow server:\n\n```bash\ncomet_for_mlflow --mlflow-store-uri http://localhost:5000\n```\n\n## Importing MLFlow artifacts stored remotely\n\nIf your MLFlow runs have artifacts stored remotely (in any of supported remote artifact stores https://www.mlflow.org/docs/latest/tracking.html#artifact-stores), you need to configure your environment the same way as when you ran those experiments. For example, with a local Minio server:\n\n```bash\nenv MLFLOW_S3_ENDPOINT_URL=http://localhost:9001 \\\n    AWS_ACCESS_KEY_ID=minio \\\n    AWS_SECRET_ACCESS_KEY=minio123 \\\n    comet_for_mlflow\n```\n\n# FAQ\n\n## How can I configure my API Key or Rest API Key?\n\nYou can either pass your Comet.ml API Key or Rest API Key as command-line flags or through the [usual configuration options](https://www.comet.com/docs/v2/api-and-sdk/python-sdk/advanced/configuration/).\n\n## How are MLFlow experiments mapped to Comet.ml projects?\n\nEach MLFlow experiment is mapped to a unique Comet.ml project ID. This way even if you rename the Comet.ml project or the MLFlow experiment, new runs will be imported in the correct Comet.ml project. The name for newly created Comet.ml is `mlflow-$MLFLOW_EXPERIMENT_NAME`. The original MLFlow experiment name is also saved as an Other field named `mlflow.experimentName`.\n\nBelow is a complete list of MLFlow experiment and run fields mapped to Comet.ml equivalent concepts:\n\n* MLFlow Experiments are mapped as Comet.ml projects\n* MLFlow Runs are mapped as Comet.ml experiments\n* MLFlow Runs fields are imported according to following table:\n\n| MLFlow Run Field \t| Comet.ml Experiment Field \t|\n|------------------\t|---------------------------\t|\n| File name        \t| File name                 \t|\n| Tags             \t| Others                    \t|\n| User             \t| Git User + System User    \t|\n| Git parent       \t| Git parent                \t|\n| Git origin       \t| Git Origin                \t|\n| Params           \t| Params                    \t|\n| Metrics          \t| Metrics                   \t|\n| Artifacts        \t| Assets                    \t|\n\n## Do I have to run this for future experiments?\n\nNo, the common pattern is to import [Comet's Python SDK with MLFlow support](https://www.comet.com/docs/v2/integrations/ml-frameworks/mlflow/) in your MLFlow projects, which will keep all future experiment runs synchronized.\n\n\n# Credits\n\nThis package was created with [Cookiecutter](https://github.com/audreyr/cookiecutter) and the [audreyr/cookiecutter-pypackage](https://github.com/audreyr/cookiecutter-pypackage) project template.\n\n\nRelease History\n===============\n\n0.1.3 (2022-12-08)\n------------------\n\n- Fix compatibility with MLFlow v2.0.1 #3\n\n0.1.2 (2020-03-12)\n------------------\n\n- Fix compatibility with Comet Python SDK v3.1.1. #2\n- Fix support for unicode project notes in Python 2. #1\n\n0.1.1 (2020-02-17)\n------------------\n\n-   Fix package URL in metadata.\n\n0.1.0 (2020-02-12)\n------------------\n\n-   First release on PyPI.\n",
    "bugtrack_url": null,
    "license": "GNU General Public License v3",
    "summary": "Extend MLFlow with Comet.ml",
    "version": "0.1.5",
    "project_urls": {
        "Homepage": "https://github.com/comet-ml/comet-for-mlflow"
    },
    "split_keywords": [
        "comet_for_mlflow"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "24cb7b5d15d514c2c9d08c6e17d5acedaa6c5db644eae28126976bfb938fab0d",
                "md5": "b5610baae200068ca7af26b54e70dd68",
                "sha256": "39d798435b32a75888f7b633811c49812483821f5aad2d9442603db8cf4896e5"
            },
            "downloads": -1,
            "filename": "comet_for_mlflow-0.1.5-py2.py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "b5610baae200068ca7af26b54e70dd68",
            "packagetype": "bdist_wheel",
            "python_version": "py2.py3",
            "requires_python": ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*",
            "size": 29719,
            "upload_time": "2023-11-17T13:11:48",
            "upload_time_iso_8601": "2023-11-17T13:11:48.449683Z",
            "url": "https://files.pythonhosted.org/packages/24/cb/7b5d15d514c2c9d08c6e17d5acedaa6c5db644eae28126976bfb938fab0d/comet_for_mlflow-0.1.5-py2.py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "169e5b230f8a0dc66be73a40faa81fae08118cdc198f95f81cd34cde4470e895",
                "md5": "e95a42ba4a6d2095072871ff14964d9c",
                "sha256": "9f4eb6a54bce112f45f5015b2f487483a9202905b63b5481b9d3dc21e94f6876"
            },
            "downloads": -1,
            "filename": "comet_for_mlflow-0.1.5.tar.gz",
            "has_sig": false,
            "md5_digest": "e95a42ba4a6d2095072871ff14964d9c",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*",
            "size": 30919,
            "upload_time": "2023-11-17T13:11:49",
            "upload_time_iso_8601": "2023-11-17T13:11:49.678098Z",
            "url": "https://files.pythonhosted.org/packages/16/9e/5b230f8a0dc66be73a40faa81fae08118cdc198f95f81cd34cde4470e895/comet_for_mlflow-0.1.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-11-17 13:11:49",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "comet-ml",
    "github_project": "comet-for-mlflow",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "tox": true,
    "lcname": "comet-for-mlflow"
}
        
Elapsed time: 1.90030s