Custom Jupyter Kernel
This short howto explains how you can create and access your own custom Jupyter Kernel inside a CoCalc. In case you require a specific software package, there are related guides: Install Python Packages and Install R Packages.
Adding a kernel for a Custom Python Environment
These instructions are for the case in which you want to create a Jupyter kernel for Python environment inside your CoCalc project.
If you haven’t already, create your own Python environment:
Python via venv (for demo purposes, we install an old version of NumPy. Make sure to install
ipykernel
as well):~$ mkdir myenv ~$ cd myenv/ ~/myenv$ python -m venv . ~/myenv$ . bin/activate (myenv) ~/myenv$ pip install ipykernel 'numpy<2' # quick check: (myenv) ~/myenv$ python Python 3.10.12 (main, Jul 29 2024, 16:56:48) [GCC 11.4.0] on linux Type "help", "copyright", "credits" or "license" for more information. >>> import numpy as np >>> np.__version__ '1.26.4'
Anaconda:
First start the root anaconda environment using
anaconda
.Then create a new environment with a prefix (important!).
Install
ipykernel
along your other packages in theenvironment.yml
configuration (example environment.yml
).Later, you can do
source ~/myenv/bin/activate
directly.
~$ anaconda (base) ~$ mamba env create --prefix ~/myenv --file=environment.yml (base) ~$ conda activate ~/myenv (/home/user/myenv) ~$ python [...]
Note
You can automatically activate your Python environment by configuring a Startup file
in a Linux Terminal, and calling the source ~/myenv/bin/activate
command.
Then test it by restarting the shell via Ctrl-d.
You can also make this permanent to all terminals by adding this to the bottom of your ~/.bashrc
Install the Jupyter Kernel:
Python via pip:
(myenv) ~/myenv$ pip install ipykernel (myenv) ~/myenv$ python -m ipykernel install --user --name=myenv --display-name "My Python Environment" # quick check: (myenv) ~/myenv$ jupyter kernelspec list | grep myenv myenv /home/user/.local/share/jupyter/kernels/myenv
Anaconda:
(/home/user/myenv) ~$ python -m ipykernel install --user --name myenv --display-name "My Python Environment"
After the above steps, when you open a Jupyter notebook, you may have to do “Refresh kernel list” at the bottom of the Kernel menu, or refresh the CoCalc tab. You will then see “My Python Environment” listed among the available kernels.
Manually adding a Jupyter Kernel
Suppose you have a kernel from another source and you would like to add it to the list of Jupyter kernels that can be selected from CoCalc Jupyter. You will need to know the command line arguments needed to start the kernel. Then follow the steps here.
For your convenience, there is a link to these instructions at the bottom of both the kernel selection menu and the kernel selection dialog.
To accomplish this, we’re working in a Linux Terminal.
If you do not already have one, you can create a terminal in Files, as a “Terminal” file with the extension *.term
.
Get a list of the currently installed kernels as follows:
/usr/local/share$ jupyter kernelspec list Available kernels: bash /ext/jupyter/kernels/bash ir /ext/jupyter/kernels/ir julia /ext/jupyter/kernels/julia octave /ext/jupyter/kernels/octave python2 /ext/jupyter/kernels/python2 python3 /ext/jupyter/kernels/python3 sagemath /ext/jupyter/kernels/sagemath [...]
Copy one of the above over that is closest to the kernel you want to create into your project’s
~/.local/share/jupyter/kernels/<kernel_name>
directory, e.g.,
mkdir -p $HOME/.local/share/jupyter/kernels
cp -arv /ext/jupyter/kernels/sagemath $HOME/.local/share/jupyter/kernels/sage_custom
Edit the
kernel.json
file copy of the kernel you made:cd $HOME/.local/share/jupyter/kernels/sage_custom open kernel.json
Make sure to change the name of the kernel, etc. E.g., you might change kernel.json
to:
{
"display_name": "sage_custom",
"argv": [
"/home/user/sage/sage",
"--python",
"-m",
"sage.repl.ipython_kernel",
"--matplotlib=inline",
"-f",
"{connection_file}"
]
}
where /home/user/sage/sage
points to your own Sage installation.
Note, $HOME
should expand to /home/user
, which you can check by running echo $HOME
.
Now, run
jupyter kernelspec list
again to check that your kernel shows up in the list of all kernels.Test your kernel in the terminal first to more easily see what is wrong (if anything):
jupyter console --kernel=sage_custom
An interactive IPython console should start up and you should be able to run Sage commands.
Once you have your kernel working in a terminal, test your kernel from a Jupyter Notebook. To load an updated list of kernels, scroll down in the “Kernel” menu and select “Refresh kernel list”. Your kernel should show up with the given
display_name
!
Note
For a Python kernel, we suggest to add these parameters to the argv
array:
"--HistoryManager.enabled=False"
: there is no need to record the history in a local database"--matplotlib=inline"
: to automatically load matplotlib