Update (August 14, 2020): This tutorial has been updated to showcase the Taxi Cab end-to-end example using the new MiniKF (v20200812.0.0)
Today, at Kubecon Europe 2019, Arrikto announced the release of the new MiniKF, which features Kubeflow v0.5. The new MiniKF enables data scientists to run end-to-end Kubeflow Pipelines locally, starting from their Notebook.
This is great news for data scientists, as until now, there was no easy way for one to run an end-to-end KFP example on-prem. One should have strong Kubernetes knowledge to be able to deal with some steps. Specifically, for Kubeflowâs standard Chicago Taxi (TFX) example, which will be the one we will presenting in this post, one should:
- Understand K8s and be familiar with kubectl
- Understand and compose YAML files
- Manually create PVCs via K8s
- Mount a PVC to a container to fill it up with initial data
Using MiniKF and Arriktoâs Rok data management platform (MiniKF comes with a free, single-node Rok license), we showcase how to streamline all these operations to reduce time, and provide a much more friendly user experience. A data scientist starts from a Notebook, builds the pipeline, and uses Rok to take a snapshot of the local data they prepare, with a click of a button. Then, they can seed the Kubeflow Pipeline with this snapshot using only the UIs of KFP and Rok.
MiniKF greatly enhances data science experience by simplifying usersâ workflow and removing the need for even a hint of K8s knowledge. It also introduces the first steps towards a unified integration of Notebooks & Kubeflow Pipelines.
In a nutshell, this tutorial will highlight the following benefits of using MiniKF, Kubeflow, and Rok:
- Easy execution of a local/on-prem Kubeflow Pipelines e2e example
- Seamless Notebook and Kubeflow Pipelines integration with Rok
- KFP workflow execution without K8s-specific knowledge
Kubeflowâs Chicago Taxi (TFX) example on-prem tutorial
Letâs put all the above together, and watch MiniKF, Kubeflow, and Rok in action.
One very popular data science example is the Taxi Cab (or Chicago Taxi) example that predicts trips that result in tips greater than 20% of the fare. This example is already ported to run as a Kubeflow Pipeline on GCP, and included in the corresponding KFP repository. We are going to showcase the Taxi Cab example running locally, using the new MiniKF, and demonstrate Rokâs integration as well. Follow the steps below and you will run an end-to-end Kubeflow Pipeline on your laptop!
Install MiniKF
Open a terminal and run:
vagrant init arrikto/minikf
vagrant up
Open a browser, go to 10.10.10.10 and follow the instructions to get Kubeflow and Rok up and running.
For more info about how to install MiniKF, visit the MiniKF page:
https://www.arrikto.com/minikf/
Or the official Kubeflow documentation:
https://www.kubeflow.org/docs/started/workstation/getting-started-minikf/
MiniKF is also available on the GCP Marketplace, where you can install it with the click of a button. You can find it here.
Create a Notebook Server
On the MiniKF landing page, click the âConnectâ button next to Kubeflow to connect to the Kubeflow Dashboard:
data:image/s3,"s3://crabby-images/05eff/05effbb206751d4822a0d06df94de78404d71368" alt="MiniKF: Connect to Kubeflow"
Log in using the credentials you see on your screen.
data:image/s3,"s3://crabby-images/20a3b/20a3b6e11ffda7e535bfcff4b7edce21d197f178" alt="Image for post"
Once at Kubeflowâs Dashboard, click on the âNotebooksâ link on the left pane to go to the Notebook Manager UI:
data:image/s3,"s3://crabby-images/03b93/03b938b27c39da5b52db5b4e29096c42bc0ef3b3" alt="Image for post"
You are now at the Kubeflow Notebook Manager, showing the list of Notebook Servers, which is currently empty. Click on âNew Serverâ to create a new Notebook Server:
data:image/s3,"s3://crabby-images/c8042/c80427475eb501dcb3a3c4b424d5328a0994fcb9" alt="Create a new Notebook Server"
Enter a name for your new Notebook Server, and select Image, CPU, and RAM.
Make sure you have selected the following Docker image:
gcr.io/arrikto/jupyter-kale:v0.5.0-47-g2427cc9
Note that the image tag may differ.
data:image/s3,"s3://crabby-images/c3e58/c3e5840a4fcc8b2343d28c530fc4d3249d8118fe" alt="Image for post"
Add a new, empty Data Volume, for example of size 2GB, and name it âdataâ (you can give it any name you like, but then you will have to modify some commands in later steps):
data:image/s3,"s3://crabby-images/d8752/d87521f136e3e3d25dada5601ff8dd33c410b770" alt="Image for post"
Once you select all options, click âLaunchâ to create the Notebook Server, and wait for it to get ready:
data:image/s3,"s3://crabby-images/c6f78/c6f78d0c6f72359f387010f3c771f39f46e0993d" alt="Image for post"
Once the Server is ready, the âConnectâ button will become active (blue color). Click the âConnectâ button to connect to your new Notebook Server:
data:image/s3,"s3://crabby-images/01c9d/01c9dff936f100b09538d1c18d4b0bbca664960d" alt="Image for post"
A new tab will open up with the JupyterLab landing page:
data:image/s3,"s3://crabby-images/7036f/7036f9330ab1d95383020021363563bbbd8be1f8" alt="Image for post"
Bring in the Pipelines code and data
Create a new terminal in JupyterLab:
data:image/s3,"s3://crabby-images/c68db/c68dbcb42affc5db30d534e8f12b6bf01a24867a" alt="Image for post"
Bring in a pre-filled Notebook to run all the necessary commands:
wget https://raw.githubusercontent.com/arrikto/kubeflow-examples/kubecon-demo/taxi-cab-on-prem/taxi-cab-pipeline-snap.ipynb
The Notebook will appear on the left pane of your JupyterLab:
data:image/s3,"s3://crabby-images/6e0f5/6e0f5f4350f5c4797ee4ad4d58f850ab0cd6846c" alt="Image for post"
Double-click the notebook file to open it and run the cells one-by-one:
data:image/s3,"s3://crabby-images/372ee/372ee092d0a74efcca098df938d5c2af623b5900" alt="Image for post"
Run the first cell to download the Arriktoâs pipeline code to run the Chicago Taxi Cab example on-prem:
data:image/s3,"s3://crabby-images/7f1d4/7f1d48ca88d3c76ae64570fa0e5d0b7e4e86870c" alt="Image for post"
Run the second cell to ingest the data:
data:image/s3,"s3://crabby-images/55ba9/55ba993cc4fc59389257918fab56e3d6d9f707cb" alt="Image for post"
Run the third cell to move the ingested data to the Data Volume of the Notebook. (Note that if you didnât name your Data Volume âdataâ, then you have to slightly modify this command):
data:image/s3,"s3://crabby-images/53c9f/53c9f6636ede6b622ed8b45e6161d40b0092e5cb" alt="Image for post"
Run the fourth cell to verify that data exist inside the Data Volume. Note that you should have the taxi-cab-classification directory under the data directory, not just the files. You now have a local Data Volume populated with the data the pipeline code needs (if you didnât give the name âdataâ to your Data Volume, then you have to make sure that your Data Volume has these files in it):
data:image/s3,"s3://crabby-images/e82d5/e82d556c6dffdb30dd6f11e68ea98d80a529865c" alt="Image for post"
Run the fifth cell to compile the pipeline source code:
data:image/s3,"s3://crabby-images/2bfd9/2bfd912c6e3e13a8060b8bafdb0bb6cbc04ef18f" alt="Image for post"
Run the sixth cell to verify the output of the compiled pipeline:
data:image/s3,"s3://crabby-images/0ab86/0ab86aa62aba2e330df5864aaebaebbdf95ac73c" alt="Image for post"
The file containing the compiled pipeline appears on the left pane of your JupyterLab:
data:image/s3,"s3://crabby-images/0d140/0d1406372302ae0e6bad3494527dbe90cd45907e" alt="Image for post"
Snapshot the Data Volume
In later steps, the pipeline is going to need the data that we brought into the Data Volume previously. For this reason, we need a snapshot of the Data Volume. As a best practice, we will snapshot the whole JupyterLab, and not just the Data Volume, in case the user wants to go back and reproduce their work.
We will use Rok, which is already included in MiniKF, to snapshot the JupyterLab. On the Kubeflow left pane, click on the âSnapshotsâ link to go to the Rok UI. Alternatively, you can go to the MiniKF landing page and click the âConnectâ button next to Rok:
data:image/s3,"s3://crabby-images/36bf6/36bf65399e82ddfab560c445b88f142d3e71579b" alt="Image for post"
This is the Rok UI landing page:
data:image/s3,"s3://crabby-images/56f96/56f96eddceeca2e0e4cc7366057ee7fe52824324" alt="Image for post"
Create a new bucket to host the new snapshot. Click on the â+â button on the top left:
data:image/s3,"s3://crabby-images/30baa/30baa88f1f0c5734fbea3ac7de24d0d4aab847a6" alt="Image for post"
A dialog will appear asking for a bucket name. Give it a name and click âNextâ. We will keep the bucket âLocalâ for this demo:
data:image/s3,"s3://crabby-images/9417a/9417a510ca7f4cabf1cae611c221580776174a86" alt="Image for post"
Clicking âNextâ will result in a new, empty bucket appearing in the landing page. Click on the bucket, to go inside:
data:image/s3,"s3://crabby-images/82830/82830a46675387e3ce1f1d33083dea88cae1ca9c" alt="Image for post"
Once inside the bucket, click on the Camera button to take a new snapshot:
data:image/s3,"s3://crabby-images/7b47b/7b47bc3648fa8d8676c99b42ea63ef7684d4a8e0" alt="Image for post"
By clicking the Camera button, a dialog appears asking for the K8s resource that we want to snapshot. Choose the whole âJupyterLabâ option, not just the single Data Volume (âDatasetâ):
data:image/s3,"s3://crabby-images/7623f/7623fe4305011bb32527868c26cc3fd5a0728496" alt="Image for post"
Most fields will be pre-filled with values automatically by Rok, for convenience. Select your JupyterLab from the dropdown list:
data:image/s3,"s3://crabby-images/a13b3/a13b3c3d6ec91eb4b21268e1bbc92bac38d94151" alt="Image for post"
Provide a commit title and a commit message for this snapshot. This is to help you identify the snapshot version in the future, the same way you would do with your code commits in Git:
data:image/s3,"s3://crabby-images/9e22d/9e22d2dbcc7a4ab55d382a61bc7f77970bb51d44" alt="Image for post"
Then, choose a name for your snapshot:
data:image/s3,"s3://crabby-images/06767/0676774d80f753ff530c00884fb568d01e1c9405" alt="Image for post"
Take the snapshot, by clicking the âSnapshotâ button:
data:image/s3,"s3://crabby-images/e907d/e907da5a0aba699b0541e45e84172d0fd642ec20" alt="Image for post"
Once the operation completes, you will have a snapshot of your whole JupyterLab. This means you have a snapshot of the Workspace Volume and a snapshot of the Data Volume, along with all the corresponding JupyterLab metadata to recreate the environment with a single click. The snapshot appears as a file inside your new bucket. Expanding the file will let you see the snapshot of the Workspace Volume and the snapshot of the Data Volume:
data:image/s3,"s3://crabby-images/687ef/687effd92277fec435b987c42acb206c4d12241f" alt="Image for post"
Now that we have both the pipeline compiled and a snapshot of the Data Volume, letâs move on to run the pipeline and seed it with the data we prepared.
Upload the Pipeline to KFP
Before uploading the pipeline to KFP, we first need to download the compiled pipeline locally. Go back to your JupyterLab and download the compiled pipeline. To do so, right click on the file on JupyterLabâs left pane, and click âDownloadâ:
data:image/s3,"s3://crabby-images/eed02/eed02f6f39770e86f79726ede16542f496b4a541" alt="Image for post"
Once the file is downloaded to your laptop, go to Kubeflow Dashboard and open the Kubeflow Pipelines UI by clicking âPipelinesâ on the left pane:
data:image/s3,"s3://crabby-images/cca09/cca0925d6727311480ea5989ac3f85380fa38a76" alt="Image for post"
This will take you to the Kubeflow Pipelines UI:
data:image/s3,"s3://crabby-images/97325/973259c0295f35ca44b024034586c0588cd7a9e2" alt="Image for post"
Click â+ Upload pipelineâ:
data:image/s3,"s3://crabby-images/a5e67/a5e675b0b81736151ee5b14ac87950988254da60" alt="Image for post"
Choose a name and a description for your pipeline. Then click the âUpload a fileâ option and choose the .tar.gz file you downloaded locally. Finally, click âCreateâ.
data:image/s3,"s3://crabby-images/63e62/63e62883f2c064489dc087d7d84db2239aa8651e" alt="Image for post"
The pipeline should get uploaded successfully and you should be seeing its graph.
data:image/s3,"s3://crabby-images/b304d/b304d08dd472b7a7aa6d1b60a8d6ce4d49c0e91a" alt="Image for post"
Create a new Experiment Run
Create a new Experiment by clicking â+ Create experimentâ:
data:image/s3,"s3://crabby-images/5e61b/5e61bb87a682101be53dbf59284224f2d740cdd8" alt="Image for post"
Choose an Experiment name, and click âNextâ:
data:image/s3,"s3://crabby-images/c7dfd/c7dfdc2f69c08ed80b13065274642f6ed3072404" alt="Image for post"
By clicking âNextâ, the KFP UI sends you to the âStart a new runâ page, where you are going to create a new Run for this Experiment. Enter a name for this Run (note that the Pipeline is already selected. If this is not the case, just select the uploaded Pipeline):
data:image/s3,"s3://crabby-images/19a46/19a465c1e0bbc24cf005d33d168198ea7fe0c212" alt="Image for post"
Note that the Pipelineâs parameters show up:
data:image/s3,"s3://crabby-images/7ed34/7ed348d6204fedc2bc7af62599a062f09c411c16" alt="Image for post"
Seed the Pipeline with the Notebookâs Data Volume
On the ârok-urlâ parameter we need to specify the snapshot of the Notebook Serverâs Data Volume, which we created in the previous step. Click on âChooseâ to open the Rok file chooser and select the snapshot of this Data Volume:
data:image/s3,"s3://crabby-images/f12de/f12dea6b5f9d42102014090bf1251d5aa2bd3bc9" alt="Image for post"
Enter inside the bucket you created previously:
data:image/s3,"s3://crabby-images/d39a8/d39a8af53e1563221bd32964f9dac844fee0c3aa" alt="Image for post"
Expand the file inside the bucket:
data:image/s3,"s3://crabby-images/fc0f3/fc0f36b16e226e84dca086223b9f3693fe9c0750" alt="Image for post"
Find the snapshot of the Data Volume and click on it. Make sure that you have chosen the Data Volume and not the Workspace Volume:
data:image/s3,"s3://crabby-images/51644/5164419e8f6425d7f5251747b16cbf714a0f9840" alt="Image for post"
Then click on âChooseâ:
data:image/s3,"s3://crabby-images/95ece/95eceee6f30465adbc98cbdce32b04f935e69295" alt="Image for post"
The Rok URL that corresponds to the Data Volume snapshot appears on the corresponding parameter field:
data:image/s3,"s3://crabby-images/f7213/f7213027e3933f3ddb5b4fbcae5d9868e45a5c15" alt="Image for post"
Select a bucket to store the pipeline snapshot
On the ârok-register-urlâ parameter we need to choose where we are going to store the pipeline snapshot. For that, we need to specify a bucket and a name for the file (snapshot) that is going to be created. We can select an existing bucket and an existing file. This would create a new version of this file. Here, we will create a new bucket and a new file. First, we click on the âChooseâ button to open the Rok file chooser:
data:image/s3,"s3://crabby-images/5ddb1/5ddb155f328c2c3d5c6aa09b5e1131c01495317e" alt="Image for post"
We create a new bucket:
data:image/s3,"s3://crabby-images/6f5af/6f5af7eda0a6707c79c1027dde7e3153c552d6e5" alt="Image for post"
We give it a name and click âNextâ:
data:image/s3,"s3://crabby-images/7c609/7c6096ec9473930403e900fd46b90a61134237f3" alt="Image for post"
Then we enter the bucket:
data:image/s3,"s3://crabby-images/e3264/e3264a0460e585efbbdc3173cd6c83f649f06cde" alt="Image for post"
We create a new file:
data:image/s3,"s3://crabby-images/e623c/e623c41dab0cd7bc94e3232bef0338c8b00ccf66" alt="Image for post"
We give it a name:
data:image/s3,"s3://crabby-images/6e82e/6e82e8783d1b50d4195ddf2363177dc96e51c61c" alt="Image for post"
And click âChooseâ:
data:image/s3,"s3://crabby-images/0d994/0d9941fce80f062bfab9e5f98ce3a6ef8a100c74" alt="Image for post"
The Rok URL that corresponds to the pipeline snapshot appears on the corresponding parameter field:
data:image/s3,"s3://crabby-images/80369/80369602a6867c4ff2f636b50067eb0fe1d61d16" alt="Image for post"
Run the Pipeline
Now that we have defined the data to seed the pipeline and the file to store the pipeline snapshot, we can run the pipeline. We are leaving all other parameters as is, and click âStartâ:
data:image/s3,"s3://crabby-images/15ae5/15ae51007b914c52d7cccd4eb725df02a5f275e1" alt="Image for post"
Now, click on the Run you created to view the progress of the Pipeline:
data:image/s3,"s3://crabby-images/1bc5b/1bc5bf085d999a584d39865468b1c574f839d971" alt="Image for post"
As the Pipeline runs, we see the various steps running and completing successfully. The Pipeline is going to take 10 to 30 minutes to complete, depending on your laptop specs. During the first step, Rok will instantly clone the snapshot we provided, for the next steps to use it:
data:image/s3,"s3://crabby-images/312e2/312e2c3a76c1fec358fc09f7c18810d1cf121e22" alt="Image for post"
Note: If the validation step fails with:
/mnt/taxi-cab-classification/column-names.json; No such file or directory
then you have to make sure that you have given the name âdataâ to your Data Volume. If not, then make sure that you amended the command of cell 3 accordingly, so that the data of the pipeline gets stored to your Data Volume.
data:image/s3,"s3://crabby-images/1efc6/1efc63dc49f6cb3eb513e175bf56c201b6e4fc96" alt="Image for post"
The training step is going to take a few minutes:
data:image/s3,"s3://crabby-images/56f08/56f08101f1bd2f1f59d3dafd29665e486adb43b7" alt="Image for post"
data:image/s3,"s3://crabby-images/69dd3/69dd35faf0930ee52b3e4af5561afeddd67bcebd" alt="Image for post"
data:image/s3,"s3://crabby-images/352ee/352ee7d6be256f0cd3c02abe225795ccf9090e00" alt="Image for post"
Pipeline snapshot with Rok
As a last step, Rok will automatically take a snapshot of the pipeline, so that we can later attach it to a Notebook and do further exploration of the pipeline results. You can see this step here:
data:image/s3,"s3://crabby-images/640d5/640d5d5d52e33c4d434359b0dea46d921cf0f6f9" alt="Image for post"
data:image/s3,"s3://crabby-images/09ab2/09ab239127b3779751c21c8c8f000471a736a585" alt="Image for post"
Update: in later versions of MiniKF, the `deploy` step will fail. This happens, because this step assumes the pipeline runs inside the `kubeflow` namespace.
If we go back to the Rok UI, we can see the snapshot that was taken during the pipeline run. We go to the Rok UI landing page:
data:image/s3,"s3://crabby-images/816c9/816c908b697f6e1afc5e19b51cdf4ddbe1303b79" alt="Image for post"
We find the bucket that we chose earlier to store the snapshot, in this case âtaxi-cab-pipeline-snapshotâ:
data:image/s3,"s3://crabby-images/79977/799776c311a61b425680643cdee72d107c4599a1" alt="Image for post"
And we see the pipeline snapshot that has the name that we chose earlier, in this case âpipeline-snapshotâ:
data:image/s3,"s3://crabby-images/43908/43908a2aec3ada76b01ee75af1f2564e14001992" alt="Image for post"
Explore pipeline results inside a Notebook
To explore the pipeline results, we can create a new Notebook and attach it the pipeline snapshot. The Notebook will use a clone of this immutable snapshot. This means that you can do further exploration and experimentation using this Data Volume, without losing the results that the pipeline run produced.
To do this, we create a new Notebook Server and add an existing Data Volume. Here, the volume will be the pipeline snapshot that lives inside Rok. We go to the Notebook Manager UI and click âNew Serverâ:
data:image/s3,"s3://crabby-images/701f0/701f0862ac298bd722d8a21605064879187156a3" alt="Image for post"
Then, we enter a name for the new Notebook Server, and select Image, CPU, and RAM:
data:image/s3,"s3://crabby-images/bc561/bc5614e54197b7b521cdc008cd60ea404f40159e" alt="Image for post"
To add an existing Data Volume, click on âAdd Volumeâ:
data:image/s3,"s3://crabby-images/45f02/45f02a618d10ac55b75847a81b3cb131ec52fdc5" alt="Image for post"
Then change its type to âExistingâ:
data:image/s3,"s3://crabby-images/3ee5d/3ee5dc778e7db4a6453a7e259ccadd720618f7de" alt="Image for post"
data:image/s3,"s3://crabby-images/ba882/ba8824c424e38dce2b358de3735cda6b35b6ab37" alt="Image for post"
Now, we will use the Rok file chooser to select the snapshot that was taken during the pipeline run. This snapshot contains the pipeline results. The Notebook will use a clone of this immutable snapshot, so you can mess with the volume without losing any of your critical data.
We click on the Rok file chooser icon and open the file chooser:
data:image/s3,"s3://crabby-images/85023/8502330f01d1a6cfeb2b102c4d505a2e68ed5ff1" alt="Image for post"
data:image/s3,"s3://crabby-images/11186/11186bb5a4dbedab8628b7f4615c54eb38042984" alt="Image for post"
We find the bucket that we chose earlier to store the snapshot, in this case âtaxi-cab-pipeline-snapshotâ:
data:image/s3,"s3://crabby-images/1ddf5/1ddf5b4f1d66d3999c8186d95efc6aa956d67fb7" alt="Image for post"
We click on the file (snapshot) that we created during the pipeline run, in this case âpipeline-snapshotâ:
data:image/s3,"s3://crabby-images/1781d/1781d205160dc68516216107f84d377bbc92644c" alt="Image for post"
And then click âChooseâ:
data:image/s3,"s3://crabby-images/c4f64/c4f64eba73fe6222e76ad07a8dec326cb513d877" alt="Image for post"
The Rok URL that corresponds to this snapshot appears in the âRok URLâ field:
data:image/s3,"s3://crabby-images/0b730/0b730cf3f41acc6ceaf38079111aef7de2ed8331" alt="Image for post"
You can change the name of the volume if you wish. Here, we change it to âanalysisâ:
data:image/s3,"s3://crabby-images/ba831/ba8314f890df455f589131165485b6c17dd86de2" alt="Image for post"
Then, we click âLaunchâ:
data:image/s3,"s3://crabby-images/6cb4e/6cb4e93a578544b615a144797bed92d7b019e90b" alt="Image for post"
A new Notebook Server appears in the Notebook Manager UI. Click on âConnectâ to go this JupyterLab:
data:image/s3,"s3://crabby-images/5a4bb/5a4bb096c010227d2032220979c228ad8fbbb9d8" alt="Image for post"
Inside the Notebook, you can see the Data Volume that we created by cloning the pipeline snapshot:
data:image/s3,"s3://crabby-images/0f8e6/0f8e611273f21d3f1bbd8bf89b11d4edd798f5a5" alt="Image for post"
Inside the Data Volume you can see the input data of the pipeline âtaxi-cab-classificationâ, and the output data of the pipeline âtaxi-cab-classification-s9qwxâ. Note that you will see a different alphanumerical sequence in your Notebook. Open the second folder to view the pipeline results:
data:image/s3,"s3://crabby-images/42882/4288254a58ff0fd949898a50ad719285cbb7aa49" alt="Image for post"
You can see the results of every step of the pipeline:
data:image/s3,"s3://crabby-images/93565/9356565c21a3a658c1cac7ff1f174561200df830" alt="Image for post"
Letâs go inside the analysis folder to see how the model performed:
data:image/s3,"s3://crabby-images/f036e/f036e38e179c36921a08d0469de6eaf666c8e1dc" alt="Image for post"
Open the âoutput_display.htmlâ file:
data:image/s3,"s3://crabby-images/81316/81316cfbacb7f54c470b14aa8fdc0a77db0def8e" alt="Image for post"
Click on âTrust HTMLâ to be able to view the file:
data:image/s3,"s3://crabby-images/b7125/b7125396126af7e50279bd9c3f6c23e2f79cb1bf" alt="Image for post"
Here is how the model performed:
data:image/s3,"s3://crabby-images/3ffad/3ffadbaeb0c657140bda7aa5f70424d21b20a0fa" alt="Image for post"
Note: this page is using HTML imports, a feature of the web components spec which is now deprecated. Most probably you wonât be able to view the model performance.
More MiniKF tutorials
- From Notebook to Kubeflow Pipelines with MiniKF & Kale
- Optimize a model using hyperparameter tuning with Kale, Katib, and Kubeflow Pipelines
Talk to us
Join the discussion on the #minikf Slack channel, ask questions, request features, and get support for MiniKF.
To join the Kubeflow Slack workspace, please request an invite.
Watch the tutorial video
You can also watch the video of this tutorial: