Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/NikeNano/kubeflow-github-action
Repository for makeinga a GitHub Actions for deploying to Kubeflow.
https://github.com/NikeNano/kubeflow-github-action
Last synced: 2 months ago
JSON representation
Repository for makeinga a GitHub Actions for deploying to Kubeflow.
- Host: GitHub
- URL: https://github.com/NikeNano/kubeflow-github-action
- Owner: NikeNano
- Created: 2020-01-19T10:14:19.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-02-16T00:01:21.000Z (almost 3 years ago)
- Last Synced: 2024-10-17T08:06:11.124Z (3 months ago)
- Language: Python
- Size: 93.8 KB
- Stars: 35
- Watchers: 2
- Forks: 18
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-actions - Compile, Deploy and Run Kubeflow Pipeline
- fucking-awesome-actions - Compile, Deploy and Run Kubeflow Pipeline
- awesome-workflows - Compile, Deploy and Run Kubeflow Pipeline
README
# This action Submits Kubeflow Pipelines to Kubeflow cluster running on Google Cloud Platform.
The purpose of this action is to allow for automated deployments of [Kubeflow Pipelines](https://github.com/kubeflow/pipelines) on Google Cloud Platform (GCP). The action will collect the pipeline from a python file and compile it before uploading it to Kubeflow. The Kubeflow deployment must be using [IAP](https://www.kubeflow.org/docs/gke/deploy/monitor-iap-setup/) on GCP to work.
# Usage
## Example Workflow that uses this action
To compile a pipeline and upload it to kubeflow:
```yaml
name: Compile and Deploy Kubeflow pipeline
on: [push]# Set environmental variables
jobs:
build:
runs-on: ubuntu-18.04
steps:
- name: checkout files in repo
uses: actions/checkout@master- name: Submit Kubeflow pipeline
id: kubeflow
uses: NikeNano/kubeflow-github-action@master
with:
KUBEFLOW_URL: ${{ secrets.KUBEFLOW_URL }}
ENCODED_GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.GKE_KEY }}
GOOGLE_APPLICATION_CREDENTIALS: /tmp/gcloud-sa.json
CLIENT_ID: ${{ secrets.CLIENT_ID }}
PIPELINE_CODE_PATH: "example_pipeline.py"
PIPELINE_FUNCTION_NAME: "flipcoin_pipeline"
PIPELINE_PARAMETERS_PATH: "parameters.yaml"
EXPERIMENT_NAME: "Default"
RUN_PIPELINE: False
VERSION_GITHUB_SHA: False```
If you also would like to run it use the following:
```yaml
name: Compile, Deploy and Run on Kubeflow
on: [push]# Set environmental variables
jobs:
build:
runs-on: ubuntu-18.04
steps:
- name: checkout files in repo
uses: actions/checkout@master- name: Submit Kubeflow pipeline
id: kubeflow
uses: NikeNano/kubeflow-github-action@master
with:
KUBEFLOW_URL: ${{ secrets.KUBEFLOW_URL }}
ENCODED_GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.GKE_KEY }}
GOOGLE_APPLICATION_CREDENTIALS: /tmp/gcloud-sa.json
CLIENT_ID: ${{ secrets.CLIENT_ID }}
PIPELINE_CODE_PATH: "example_pipeline.py"
PIPELINE_FUNCTION_NAME: "flipcoin_pipeline"
PIPELINE_PARAMETERS_PATH: "parameters.yaml"
EXPERIMENT_NAME: "Default"
RUN_PIPELINE: True
VERSION_GITHUB_SHA: False```
The repo also contains an example where the containers in the pipeline are versioned with the github hash in order to improve operations and tracking of errors. However this requires that the pipelines function to be wrapped in a function with one argument:```python
def pipeline(github_sha :str):
...
```the containers is versioned with the hash:
```python
pre_image = f"gcr.io/{project}/pre_image:{github_sha}"
train_forecast_image = f"gcr.io/{project}/train_forecast_image:{github_sha}"```
for example see [here](https://github.com/NikeNano/kubeflow-github-action/blob/master/forecast_peython_wiki/deployment/pipline.py)## Mandatory inputs
1) KUBEFLOW_URL: The URL to your kubeflow deployment
2) GKE_KEY: Service account with access to kubeflow and rights to deploy, see [here](http://amygdala.github.io/kubeflow/ml/2019/08/22/remote-deploy.html) for example, the credentials needs to be bas64 encode:``` bash
cat path-to-key.json | base64
```
3) GOOGLE_APPLICATION_CREDENTIALS: The path to where you like to store the secrets, which needs to be decoded from GKE_KEY
3) CLIENT_ID: The IAP client secret
4) PIPELINE_CODE_PATH: The full path to the python file containing the pipeline
5) PIPELINE_FUNCTION_NAME: The name of the pipeline function the PIPELINE_CODE_PATH file
6) PIPELINE_PARAMETERS_PATH: The pipeline parameters
7) EXPERIMENT_NAME: The name of the kubeflow experiment within which the pipeline should run
8) RUN_PIPELINE: If you like to also run the pipeline set "True"
9) VERSION_GITHUB_SHA: If the pipeline containers are versioned with the github hash# Future work
Add so that pipelines can be scheduled to run as well. Soooon done!