-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #14 from StatCan/update-read-me
docs: update README for local development
- Loading branch information
Showing
1 changed file
with
93 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,31 +1,115 @@ | ||
[(Français)](#interface-de-programmation-dapplications-jupyter) | ||
|
||
## Jupyter Application Programming Interfaces | ||
# Jupyter Application Programming Interfaces | ||
|
||
A Golang replacement for the [Kubeflow](https://github.com/kubeflow/kubeflow) Jupyter Web APIs. | ||
A Golang replacement for the [Kubeflow][] Jupyter Web APIs. | ||
|
||
### How to Contribute | ||
## How to Contribute | ||
|
||
See [CONTRIBUTING.md](CONTRIBUTING.md) | ||
|
||
## Developement Environment | ||
|
||
### 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` (or use an | ||
alternative YAML config) | ||
|
||
### 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. | ||
|
||
1. Change directory to front-end folder: `cd frontend` | ||
2. Install dependencies: `npm install` | ||
3. Run the front-end `KF_USER_ID=<profile_name> 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 (Preferred) | ||
|
||
This deploys a Kubeflow cluster on your local machine and requires at least 50GB | ||
of disk space. 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`. | ||
|
||
#### 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 the correct AKS | ||
cluster | ||
|
||
### License | ||
|
||
Unless otherwise noted, the source code of this project is covered under Crown Copyright, Government of Canada, and is distributed under the [MIT License](LICENSE). | ||
Unless otherwise noted, the source code of this project is covered under Crown | ||
Copyright, Government of Canada, and is distributed under the | ||
[MIT License](LICENSE). | ||
|
||
The Canada wordmark and related graphics associated with this distribution are protected under trademark law and copyright law. No permission is granted to use them outside the parameters of the Government of Canada's corporate identity program. For more information, see [Federal identity requirements](https://www.canada.ca/en/treasury-board-secretariat/topics/government-communications/federal-identity-requirements.html). | ||
The Canada wordmark and related graphics associated with this distribution are | ||
protected under trademark law and copyright law. No permission is granted to use | ||
them outside the parameters of the Government of Canada's corporate identity | ||
program. For more information, see [Federal identity requirements][]. | ||
|
||
______________________ | ||
--- | ||
|
||
## Interface de programmation d'applications Jupyter | ||
|
||
Un remplacement Golang pour les API de Web de Jupyter, partie de [Kubeflow](https://github.com/kubeflow/kubeflow). | ||
Un remplacement Golang pour les API de Web de Jupyter, partie de [Kubeflow][]. | ||
|
||
### Comment contribuer | ||
|
||
Voir [CONTRIBUTING.md](CONTRIBUTING.md) | ||
|
||
### Licence | ||
|
||
Sauf indication contraire, le code source de ce projet est protégé par le droit d'auteur de la Couronne du gouvernement du Canada et distribué sous la [licence MIT](LICENSE). | ||
Sauf indication contraire, le code source de ce projet est protégé par le droit | ||
d'auteur de la Couronne du gouvernement du Canada et distribué sous la | ||
[licence MIT](LICENSE). | ||
|
||
Le mot-symbole « Canada » et les éléments graphiques connexes liés à cette | ||
distribution sont protégés en vertu des lois portant sur les marques de commerce | ||
et le droit d'auteur. Aucune autorisation n'est accordée pour leur utilisation à | ||
l'extérieur des paramètres du programme de coordination de l'image de marque du | ||
gouvernement du Canada. Pour obtenir davantage de renseignements à ce sujet, | ||
veuillez consulter les [Exigences pour l'image de marque][]. | ||
|
||
Le mot-symbole « Canada » et les éléments graphiques connexes liés à cette distribution sont protégés en vertu des lois portant sur les marques de commerce et le droit d'auteur. Aucune autorisation n'est accordée pour leur utilisation à l'extérieur des paramètres du programme de coordination de l'image de marque du gouvernement du Canada. Pour obtenir davantage de renseignements à ce sujet, veuillez consulter les [Exigences pour l'image de marque](https://www.canada.ca/fr/secretariat-conseil-tresor/sujets/communications-gouvernementales/exigences-image-marque.html). | ||
[exigences pour l'image de marque]: | ||
https://www.canada.ca/fr/secretariat-conseil-tresor/sujets/communications-gouvernementales/exigences-image-marque.html | ||
[federal identity requirements]: | ||
https://www.canada.ca/en/treasury-board-secretariat/topics/government-communications/federal-identity-requirements.html | ||
[install go]: https://golang.org/dl/ | ||
[kubeflow]: https://github.com/kubeflow/kubeflow |