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
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-pipelineswith the--urloption - 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
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 metaflow_kubeflow-0.0.3.tar.gz.
File metadata
- Download URL: metaflow_kubeflow-0.0.3.tar.gz
- Upload date:
- Size: 29.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
40e190aed2b0abf9bc75b49679a3045c660fe8f43d3164c71504a907dcd206a3
|
|
| MD5 |
6fa25e1864e132d215ffc320f2bffd83
|
|
| BLAKE2b-256 |
662cbeb9dd0a857671e94fbdb40246a8e70abd8bc419f9a0dcd7077078b93b64
|
Provenance
The following attestation bundles were made for metaflow_kubeflow-0.0.3.tar.gz:
Publisher:
publish.yml on outerbounds/metaflow-kubeflow
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
metaflow_kubeflow-0.0.3.tar.gz -
Subject digest:
40e190aed2b0abf9bc75b49679a3045c660fe8f43d3164c71504a907dcd206a3 - Sigstore transparency entry: 815090100
- Sigstore integration time:
-
Permalink:
outerbounds/metaflow-kubeflow@cf54b9d4830740c0fea81830ea5dd7f97eaebe35 -
Branch / Tag:
refs/tags/0.0.3 - Owner: https://github.com/outerbounds
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@cf54b9d4830740c0fea81830ea5dd7f97eaebe35 -
Trigger Event:
release
-
Statement type:
File details
Details for the file metaflow_kubeflow-0.0.3-py3-none-any.whl.
File metadata
- Download URL: metaflow_kubeflow-0.0.3-py3-none-any.whl
- Upload date:
- Size: 33.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6e712f5b88cdac7b81998d866435aa8646b87da7d670547b172f673e06f83d44
|
|
| MD5 |
f718ab452f0ca464253a4542f1266022
|
|
| BLAKE2b-256 |
58f5d811bdcea4ab6ed5ee7b66188e0503ec9e5983b26c3d072e1ec72d690445
|
Provenance
The following attestation bundles were made for metaflow_kubeflow-0.0.3-py3-none-any.whl:
Publisher:
publish.yml on outerbounds/metaflow-kubeflow
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
metaflow_kubeflow-0.0.3-py3-none-any.whl -
Subject digest:
6e712f5b88cdac7b81998d866435aa8646b87da7d670547b172f673e06f83d44 - Sigstore transparency entry: 815090103
- Sigstore integration time:
-
Permalink:
outerbounds/metaflow-kubeflow@cf54b9d4830740c0fea81830ea5dd7f97eaebe35 -
Branch / Tag:
refs/tags/0.0.3 - Owner: https://github.com/outerbounds
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@cf54b9d4830740c0fea81830ea5dd7f97eaebe35 -
Trigger Event:
release
-
Statement type: