This is the first part of a multi-part series that shows how to set up Jupyter Hub for an engineering programming class. This is my first time setting up a Jupyter Hub server. I am primarily writing to my future self as I may need to set up a Jupyter Hub server again for a different class in another quarter. I hope the lessons learned will also help other instructors tackle the same problem if they want to set up Jupyter Hub for their own class or team.
Why Jupyter Hub?
Why Jupyter Hub? I am teaching an intro engineering course this summer. The course has a lab component and three of the labs are devoted to computer programming. In previous quarters, I've taught MATLAB for the three computer programming labs. But this summer, I want to try teaching Python and cover the same concepts and learning outcomes.
If we use Python in the three programming labs this summer, I would like to spend the lab time coding and solving problems. I don't want to spend time during the class downloading Python, creating virtual environments, troubleshooting installs, dealing with system vs. non-system versions of Python, installing packages, dealing with folder structure, explaining the difference between conda and pip, teaching command-line commands, going over Python on Windows compared to Python on MacOSX...
I imagine the first programming lab of the quarter runs like:
- There is a .pdf or google doc posted on a shared google drive folder with a link to Jupyter Hub
- Students click the link and bring up the login page
- Students log-in with their college usernames and passwords
- Students type
import this
press [Shift+Enter] and their first code cell just runs. - Students can use Jupyter Hub from any computer with a web browser and an internet connection.
- Jupyter Hub looks and runs the same on all student computers
This is theoretically possible with Jupyter Hub
Jupyter Hub can be installed on a Digital Ocean droplet (a cloud server, like AWS or Google Cloud). The version of Python running the notebooks created by Jupyter Hub can contain the full Anaconda distribution of packages plus some extra packages like pint and pyserial. All of the notebooks will use the same environment. The installed packages will be the same for each student. One Digital Ocean droplet will be able to run all of the notebooks at the same time (hopefully, there will be about 24 students). Student's work will be saved on the server under their user account. Students can download the .ipynb files and upload them to google drive or save the .ipynb files on a thumb drive. After the students login, folders and notebooks can be in place and used as starting points in lab and as lab exercises. After the course ends, students will still be able to log in and use Jupyter Hub and practice writing and running Python code to solve engineering problems.
What will it take to make Jupyter Hub a reality?
This list will surely change as I go through the process of setting up the Jupyter Hub server. Below are the steps I expect to take and software/hardware needed at each step.
- Sign up for a Digital Ocean Account (already done)
- Create a new Digital Ocean Droplet (will be called the server from here on out)
- Connect to the server over SSH and set up SSH keys
- Create a non-root sudo user on the server
- Get a public url, hook up the server DNS record to the public URL
- Install Anaconda on the server
- Install the other packages on the server like jupyter hub, node, pyserial and pint
- Edit permissions of files and directories on the server
- Create and implement SSL certificates on the server
- Run Jupyter Hub as a non-root sudo user
- Connect google OAuth to Jupyter Hub
- Connect to the server as student and celebrate teaching Python without worrying about installation and virtual environments.
Will this work? How much time will it take?
Will this work? I hope so. Other people have done it. There was a JupyterCon talk about it, there are example implementations up on github. A large data science class at UC Berkeley ran Jupyter Hub.
I don't really know how long it will take. The only real step that takes time is the DNS connection. The rest of the steps are in the minute time frame of computing time and probably days if not weeks of troubleshooting time. I'm just going to try and complete a step per day or a step per week and see if I can get the server going by the end of the spring quarter.
Next Steps:
The next step is really the first step:
Create SSH keys. We'll need a public/private SSH key pair to be able to log into the Jupyter Hub server over SSH.