Simplify launching a JupyterLab app, with Python and R, on the HT computing cluster
You must have a working conda installation and access to the HT computing cluster.
This project:
- creates a conda virtual environment, called
jupyterlab
, with the dependencies defined into theenvironment.yml
file - copies, into your home directory, a slurm script to launch JupyterLab using the above env
First of all, cd into your working directory and digit:
git clone https://gitlab.fht.org/hds-center/jupyterlab-launcher.git
cd jupyterlab_launcher
make setup
After a few minutes your conda environment will be ready, and you can start Jupyterlab with:
cd $HOME
sbatch launch_jupyterlab.sbatch
You can check the status of your launch_jupyter.sbatch job on a SLURM cluster with:
squeue -u $(whoami)
and the output will be available in the $job-id_jupyterlab.log
file in your home directory.
Once the job has started, we can't access the compute nodes directly, so we have to bridge to them using port forwarding.
First, we need to know in which node and port Jupyterlab is running on. Most likely this will be port 8890, but can be different.
If you want to be sure, just look at $job-id_jupyterlab.log
and check for something like this at the end of file:
[I 2022-10-19 16:31:13.141 ServerApp] Jupyter Server 1.21.0 is running at:
[I 2022-10-19 16:31:13.141 ServerApp] http://cnode23:8890/lab?token=1ac91f8df807e4b22888207ccb19897967161e60c7a0
where:
- cnode23 is the remote node that is running jupyterlab
- and 8890 is the remote port used by jupyterlab
Open a new shell on your computer and connect to that compute node and port in this way:
ssh -L 8890:cnode23:8890 username@hpclogin.fht.org
The first half specifies port forwarding and the second half specifies the user on the remote host.
ssh -L local_port:remote_node:remote_port user@remote_host
You have to keep this terminal open as long as jupyterlab runs. It may be helpful to use tmux or screen.
Copy the http://127.0.0.1:8890/lab?token=1ac91f8df807e....
url you have at the end of jupyterlab.log
file and put in your browser.
This will open Jupyterlab in your browser, but the commands will execute in your remote computing node.
If you need to use a new python module, simply add it into the environment.yml
file and run make update
To ensure other users can’t access your notebook, Jupyter Notebook servers can include a password for security,
To create a password, you first need to generate a config file:
jupyter server --generate-config
Running this command creates a configuration file at the following location:
~/.jupyter/jupyter_server_config.py
Then enter the following command to create a server password.
jupyter server password
After you enter a password a hashed version will be written to ~/.jupyter/jupyter_server_config.json . It is okay if the hashed version is public.
Now JupyterLab is secure, and you will be able to log in with a password using the http://127.0.0.1:8890/
url without the token.