File: README.Debian.md

package info (click to toggle)
jupyterhub 3.0.0%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 7,124 kB
  • sloc: python: 24,307; javascript: 1,772; makefile: 179; sh: 56
file content (41 lines) | stat: -rw-r--r-- 1,679 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# Setting up Jupyterhub

This is a work-in-progress documentation on how to set up Jupyterhub
using the Debian packages.

## Setting up HTTPS

If your Jupyterhub instance is meant to be public, you really need to
set up HTTPS so that passwords do not fly over the network in
cleartext.  Several setups are possible.

### HTTPS is managed outside of Jupyterhub

For instance, you have an Apache or Nginx reverse-proxy. In this
situation, no particular configuration is required for Jupyterhub, but
you need to obtain certificates and configure the reverse-proxy to use
them. A simple way is to get certificates from Let's Encrypt using
Certbot. Install the `certbot` package as well as
`python3-certbot-apache` (or `python3-certbot-nginx`), then run
`certbot --apache` (or `certbot --nginx`) and follow the instructions.

More detailed instructions can be found at https://certbot.eff.org/
(you can skip the part about installing Certbot with Snap since Debian
provides packages).

### HTTPS is handled by Jupyterhub directly.

This involves two steps:

1. Creating or obtaining SSL/TLS certificates: as above, Certbot can
   be of use. Run `certbot --apache certonly` or `certbot --nginx
   certonly` to get certificates.

2. Configuring Jupyterhub to use the certificates: edit the
   `/etc/jupyterhub/jupyterhub_config.py` file, and uncomment and fill
   the lines about `c.JupyterHub.ssl_cert` and
   `c.JupyterHub.ssl_key`. If you used Certbot, then the appropriate
   values are `/etc/letsencrypt/live/<yourhostname>/fullchain.pem` and
   `/etc/letsencrypt/live/<yourhostname>/privkey.pem` respectively.

You need to restart Jupyterhub, with `systemctl restart jupyterhub`.