Skip to main content

Kubeflow Pipeline extension for Metaflow

Project description

Kubeflow Pipelines extension for Metaflow

Compile and run Metaflow flows on Kubeflow Pipelines (argo workflows backend).

Basic Usage

  • Have access to a Kubeflow Pipelines instance with the API server URL.
  • Use the CLI commands to compile your flow into a Kubeflow Pipeline and deploy it.

Youtube Screencast

metaflow kubeflow demo

Compiling and Deploying a Pipeline

python my_flow.py kubeflow-pipelines --url https://my-kubeflow-instance.com create

This command will:

  • Compile your Metaflow flow into a Kubeflow Pipeline YAML specification
  • Upload it to your Kubeflow Pipelines instance
  • Create a new version of the pipeline

Accessing Kubeflow Pipelines for Deployment

Metaflow needs to be able to connect to Kubeflow Pipelines for deployment. If you have connectivity already set up, you don't need to do anything.

If you can't connect to the service directly, you can set up a port forward to the service:

kubectl port-forward -n kubeflow svc/ml-pipeline-ui 8081:80

After this, you can specify the service URL as http://localhost:8081 in one of these ways:

  • On the CLI for kubeflow-pipelines with the --url option
  • In the Metaflow config, specify "METAFLOW_KUBEFLOW_PIPELINES_URL": "http://localhost:8081"
  • Set an environment variable, METAFLOW_KUBEFLOW_PIPELINES_URL=http://localhost:8081

Available Commands

1. create - Compile and/or Deploy Pipeline

Compile a new version of your flow to Kubeflow Pipelines:

Recurring Runs: If your flow is decorated with @schedule, this command will automatically create or update the corresponding Recurring Run in Kubeflow Pipelines.

python my_flow.py kubeflow-pipelines \
    --url https://my-kubeflow-instance.com \
    create \
    --version-name v1.0.0 \
    --experiment "My Production Experiment" \
    --alpha 0.5

Options:

  • --experiment: The experiment name to create the recurring run under (if @schedule is present). Defaults to "Default".
  • --version-name: Allows one to deploy a custom version name. Else, a new version with UTC timestamp is created.
  • --only-yaml: Print the YAML specification to stdout and exit without uploading to Kubeflow Pipelines.
  • Flow Parameters: Any flow parameters (e.g., --alpha) passed here will be baked into the recurring run configuration (if @schedule is present), overriding the defaults defined in your code.

Use --help for all available options including tags, namespace, max-workers, and production token management.

2. trigger - Execute Pipeline

Trigger an execution of your deployed pipeline:

python my_flow.py kubeflow-pipelines \
    --url https://my-kubeflow-instance.com \
    trigger \
    --experiment my-experiment \
    --alpha 0.1 \
    --max-epochs 100

Flow parameters can be passed as command-line arguments. Use --help for all available options.

By default, the latest version of the deployed pipeline is used for the trigger. Else, one can also pass in a custom version using --version-name.

3. status - Check Execution Status

Fetch the status of a running or completed pipeline execution:

python my_flow.py kubeflow-pipelines \
    --url https://my-kubeflow-instance.com \
    status \
    --kfp-run-id abc-123-def-456

Use --help for all available options.

4. terminate - Terminate Execution

Terminate a running pipeline execution:

python my_flow.py kubeflow-pipelines \
    --url https://my-kubeflow-instance.com \
    terminate \
    --kfp-run-id abc-123-def-456

Use --help for all available options.

5. delete - Delete a Deployed Pipeline

Delete the flow definition and all its associated versions from Kubeflow Pipelines.

This command also searches for and deletes any associated Recurring Runs (Schedules) to ensure no orphaned schedules continue trying to trigger deleted pipelines.

In essence, this undeploys the pipeline but preserves execution history (runs) and artifacts.

python my_flow.py kubeflow-pipelines \
    --url https://my-kubeflow-instance.com \
    delete

Use --help for all available options.

Fin.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

metaflow_kubeflow-0.0.4.tar.gz (29.6 kB view details)

Uploaded Source

Built Distribution

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

metaflow_kubeflow-0.0.4-py3-none-any.whl (33.4 kB view details)

Uploaded Python 3

File details

Details for the file metaflow_kubeflow-0.0.4.tar.gz.

File metadata

  • Download URL: metaflow_kubeflow-0.0.4.tar.gz
  • Upload date:
  • Size: 29.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for metaflow_kubeflow-0.0.4.tar.gz
Algorithm Hash digest
SHA256 1cc647e17559bf8badeb8f0a509eb5bcf1de896bc22e608f35d0fcced0193a79
MD5 20227e96c1af85b4a68e057e9105658f
BLAKE2b-256 f9b8095039e58086a124bc55e2bbb60db9169f01cb72eb8d7d4f237799beea73

See more details on using hashes here.

Provenance

The following attestation bundles were made for metaflow_kubeflow-0.0.4.tar.gz:

Publisher: publish.yml on outerbounds/metaflow-kubeflow

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file metaflow_kubeflow-0.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for metaflow_kubeflow-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 1a034713767c1e7ef0f01b8a29734ebb3f896067ae65d4440ef74210b5439025
MD5 20a83ee1ffe800ed5d19e7d444f805b2
BLAKE2b-256 0aa5ad24a6ad92c3512a19be4cdbe1ed2085c4dfc458c30b1f0aa6fa3a766a93

See more details on using hashes here.

Provenance

The following attestation bundles were made for metaflow_kubeflow-0.0.4-py3-none-any.whl:

Publisher: publish.yml on outerbounds/metaflow-kubeflow

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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