bryanpaget / jupyter-apis

A Golang replacement for the Kubeflow Jupyter Web APIs / Un remplacement Golang pour les API de Web de Jupyter, partie de Kubeflow

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

(Français)

Jupyter Application Programming Interfaces

A Golang replacement for the Kubeflow Jupyter Web APIs.

How to Contribute

See CONTRIBUTING.md

Development Environment

Note that the frontend will report errors when calling /api/namespaces when run locally. This issue does not arise in production, as the /api/namespaces endpoint is unused.

To initialize the .env file for the development environment, use task env. You will need to fill out your kubeflow cloud account and kubeflow namespace information manually. The thunder-tests folder contains configuration for testing requests against the backend. Use the vscode THUNDER CLIENT extension to load the tests.

Run API Server

The API server will connect to the Kubeflow cluster from your current kubectl context. See Connecting a Kubeflow cluster below for options.

  1. Install Go
  2. Change directory to project root: cd jupyter-apis
  3. Run go run . -spawner-config samples/spawner_ui_config.yaml

Alternatively,

  1. task go:dev -w -- -spawner-config samples/spawner_ui_config.yaml will live-reload the Go server upon changes.

Recommended

You can use the vscode debugger to run the backend, just copy the below contents to a file at path .vscode/launch.json.

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Debug jupyter-api backend",
            "type": "go",
            "request": "launch",
            "mode": "debug",
            "program": ".",
            "args": [
                "-spawner-config",
                "samples/spawner_ui_config.yaml",
            ],
            "envFile": "${workspaceFolder}/.env"
        }
    ]
}

Run Front-End

The front-end is configured to proxy requests to the local API server. It requires an environment variable (KF_USER_ID) to specify the current user – this is passed to the API server as an HTTP header.

The following can be pasted in a script and executed. This uses the latest node lts version(v16.16.0). NOTE: user is when using vagrant. Use the email adress if it is the dev cluser (please never connect to prod directly)

cd frontend/common/kubeflow-common-lib
npm i
npm run build
cd dist/kubeflow
npm link

cd ../../../../jupyter
npm i
npm link kubeflow --legacy-peer-deps
KF_USER_ID=user npm start

For the kubecost data to be retrievable, the following will need to be executed kubectl port-forward -n kubecost-system deployment/kubecost-cost-analyzer 9090

Older instructions

  1. Change directory to front-end folder: cd frontend
  2. Install dependencies: npm install
  3. Run the front-end KF_USER_ID=<cloud_email> npm start

The front-end is now available at http://localhost:4200/jupyter/. Since it is disconnected from the centraldashboard component, you need to type your desired namespace in the UI rather than selecting it from a dropdown.

Connecting a Kubeflow Cluster

The API server will connect to the Kubeflow cluster from your current kubectl context. Here are a couple options for setting that up.

Local MiniKF Cluster

This deploys a Kubeflow cluster on your local machine and requires at least 50GB of disk space and the recommanded RAM is 12 Gb. First, create the miniKF cluster:

  1. Install Vagrant and Virtual Box.
  2. Create a new directory and run vagrant init arrikto/minikf and then vagrant up (takes about 20 minutes to boot).
  3. Navigate to http://10.10.10.10.
  4. Follow on-screen steps to start Kubeflow and Rok (takes about another 20 minutes).
  5. From here, you can use Kubeflow and Rok.

Then configure kubectl to connect to your new cluster:

  1. Download the miniKF kubectl config file from http://10.10.10.10.
  2. Use the downloaded configuration for kubectl, either replacing, or merging it into, ~/.kube/config.
  3. Ensure kubectl config current-context is pointing to your local cluster.

Your KF_USER_ID can be the default user that was created for your miniKF cluster (typically user).

Each time you need to start the cluster, navigate to the directory you created and run vagrant up.

Note: after some experimentation, it was found that the vagrant file could be modified on line 57 to use 8gb instead of the default 12.

  config.vm.provider "virtualbox" do |vb|
    # Display the VirtualBox GUI when booting the machine
    #vb.gui = true

    # Customize the amount of memory on the VM:
    vb.memory = "8192"
  end

Remote AKS Cluster

  1. Install Azure CLI az and kubectl
  2. Login with az and set your subscription
  3. Run az aks get-credentials for the desired remote cluster
  4. Ensure kubectl config current-context is pointing to correct cluster

On platform testing

Any push to an open PR that has the auto-deploy label on it allows developers to opt-in to on-platform testing. For example, when you need to build in github and test on platform (or want someone else to be able to pull your image):

  1. open a PR and add the auto-deploy label
  2. push to your PR and watch the GitHub Action CI
  3. access your image in Kubeflow DEV via a custom image from any of:
    • k8scc01covidacrdev.azurecr.io/IMAGENAME:SHA
    • k8scc01covidacrdev.azurecr.io/IMAGENAME:SHORT_SHA

Whats Different?

Routes are defined in this repository here.

Upstream, the endpoints are structures via request type (e.g. GET, PUT, DELETE).

Note

  • that not all endpoints are included in the golang implementation
  • to find the upstream endpoint, load the Upstream and use search with the endpoint text!
Request Type Golang Endpoint Upstream Python Endpoint Purpose
GET /api/config /api/config
GET /api/gpus /api/gpus
GET /api/storageclasses/default /api/storageclasses/default
GET /api/namespaces/{namespace}/cost/allocation Not found Get the kubecost Allocation API
GET /api/namespaces /api/namespaces Get the list of namespaces
GET /api/namespaces/{namespace} Not found Get namespace metadata
GET /api/namespaces/{namespace}/notebooks /api/namespaces/<namespace>/notebooks Get the list of notebooks
POST /api/namespaces/{namespace}/notebooks /api/namespaces/<namespace>/notebooks Create a notebook
DELETE /api/namespaces/{namespace}/notebooks/{notebook} /api/namespaces/<namespace>/notebooks/ Update a notebook
PATCH /api/namespaces/{namespace}/notebooks/{notebook} /api/namespaces/<namespace>/notebooks/<notebook Delete a notebook
GET /api/namespaces/{namespace}/pvcs /api/namespaces/<namespace>/pvc List PVCs
DELETE /api/namespaces/{namespace}/pvcs/{pvc} /api/namespaces/<namespace>/pvcs/ Delete a PVC
GET /api/namespaces/{namespace}/poddefaults /api/namespaces/<namespace>/poddefaults Get PodDefaults for a given namespace

About

A Golang replacement for the Kubeflow Jupyter Web APIs / Un remplacement Golang pour les API de Web de Jupyter, partie de Kubeflow

License:Other


Languages

Language:TypeScript 67.0%Language:HTML 13.9%Language:Go 12.9%Language:SCSS 5.1%Language:JavaScript 0.6%Language:Dockerfile 0.3%Language:CSS 0.2%