Pre-requisites: Docker, Bourne shell
I upgraded my Jupyter setup today and I though I would publish the script I am using to launch it:
#!/bin/sh
cd $HOME/Documents/jupyter
docker pull jupyter/datascience-notebook
docker build -t jupyter - <<EOD
FROM jupyter/datascience-notebook
RUN pip install --upgrade pip
RUN pip install rdflib
ENTRYPOINT ["jupyter", "lab", "--ip=0.0.0.0", "--allow-root"]
EOD
nohup docker run \
--rm \
--name jupyter \
-v "$HOME"/.jupyter:/home/joyvan/.jupyter \
-v "$PWD":/home/jovyan/work \
-v $HOME/Documents/GitHub:/home/jovyan/work/GitHub \
-p 0.0.0.0:8888:8888 \
jupyter &
cat <<EOT
To find out the token, use:
docker exec jupyter jupyter notebook list
To set a password, use:
docker exec -it jupyter jupyter notebook password
To stop use:
docker exec jupyter jupyter notebook stop
EOT
This launches a docker image that makes Jupyter Lab available on port 8888. It maps three "volumes" into this image:
- $HOME/.jupyter: This stores your Jupyter settings like theme and password.
- $HOME/Documents/jupyter: Where you will keep your Jupyter Notebooks, found under work in the Jupyter file browser.
- $HOME/Documents/GitHub: Where you keep your GitHub checkouts, found under work/GitHub in Jupyter.
Jupyter requires a token or password to access it. You can determine the token with the command:
docker exec jupyter jupyter notebook list
It is more convenient to set a password, which you can do with the command:
docker exec -it jupyter jupyter notebook password
If you need to stop Jupyter, you can do so with the command:
docker exec jupyter jupyter notebook stop
A final tip: If you need to access other services on your localhost (say services from other Docker containers mapped to local ports) from Jupyter, using localhost or 127.0.0.1 will not work because Jupyter is running inside Docker. Instead you should use host.docker.internal as the hostname instead.
No comments:
Post a Comment