Skip to content

Latest commit

 

History

History
38 lines (30 loc) · 2.17 KB

README.md

File metadata and controls

38 lines (30 loc) · 2.17 KB

jupyterhub-engr114

This repo contains the shared files used to create a JupyterHub server on Digital Ocean using an Nginx proxy server and SSL security. This deployment is for an Engineering Programming class (ENGR114) at Portland Community College during Winter 2019.

Deployment Docs

Docs for this deployment of JupyterHub can be found here:

https://professorkazarinoff.github.io/jupyterhub-engr114/

For another deployment of JupyterHub on Digital Ocean with Nginx proxy. See these blog posts:

https://pythonforundergradengineers.com/why-jupyter-hub.html

Basic Steps

  1. Get SSH public and private keys with PuTTYgen. Save SSH keys in Documents/ssh-keys
  2. Create a new Digital Ocean Droplet (DO server) running Ubuntu 18.04. Include SSH key when Droplet is created
  3. Log into DO server as root with PuTTY and SSH keys. Create a non-root sudo user (username: peter).
  4. Log into DO server as non-root sudo user with PuTTY and SSH keys
  5. Install Miniconda
  6. Create a conda env with Python 3.6
  7. Conda install packages including numpy, pandas, matplotlib, jupyter, notebook, scipy, sympy, pyserial and xlrd
  8. Conda install -c conda-forge jupyterhub pint
  9. Run JupyterHub (for just a minute) without SSL to see if it works. Go to the DO server IP address and start a notebook.
  10. Link a Google domain to DO name servers. In the Digital Ocean DNS dashboard, link domain name to DO server.
  11. Create SSL keys with let's encrypt
  12. Modify jupyterhub_config.py to include SSL keys
  13. Install Nginx
  14. Modify Nginx config to move traffic to JupyterHub and use SSL cirts
  15. Run jupyterhub as a system service
  16. Start Nginx and JupyterHub. Should be able to go to https://domain.org and start, run and save a Jupyter notebook.
  17. Set JupyterLab as the default interface (instead of the regular Jupyter notebook interface)
  18. Add authentication for GitHub usernames and passwords
  19. Add authentication for Google usernames and passwords
  20. Add custom login page
  21. Pull assignments and notes down from GitHub each time a student logs into JupyterHub.
  22. Celebrate!