Blogs

Kinetica with JupyterLab Tutorial

Share
In this article

Introduction

JupyterLab is an integrated environment that can streamline the development of Python code and Machine Learning (ML) models in Kinetica. With it you can edit Jupyter notebooks that integrate code execution, debugging, documentation, and visualization in a single document that can be consumed by multiple audiences.

The development process is streamlined because sections of code (or cells) can be run iteratively while updating results and graphs. It can be accessed from a web browser and supports a Python console with tab completions, tooltips, and visual output. One of the difficulties of using Jupyter notebooks with Kinetica had been that an environment needs to be installed with all the necessary dependencies. In this tutorial we will simplify this process with a Docker image that integrates the components so they can run locally on any Intel-based machine.

The image integrates the following major components:

  • CentOS 7
  • Kinetica 6.2
  • JupyterLab
  • Python 3.6

The Python environment has the necessary modules for:

  • Interaction with Kinetica using ODBC or the native API
  • Creating and executing Kinetica UDFs
  • Execution of ML Models on Kinetica (e.g. Pandas, PyTorch, TensorFlow)
The Kinetica Intel build does not give GPU-accelerated performance and should be used for development purposes only

Prerequisites

If you don’t already have Docker you can download it from the Docker store:

Get the Mac version here:

https://store.docker.com/editions/community/docker-ce-desktop-mac

Get the Windows version here:

https://store.docker.com/editions/community/docker-ce-desktop-windows

After installing, select the Advanced preferences and allocate at least 6GB of memory for the VM as shown below.

You will also need a trial license key for Kinetica that can be obtained from https://www.kinetica.com/trial/.

kinetica-jupyterlab Contents

All the required code is available in the kinetica-jupyterlab Git repository:

You can use git clone to fetch a local copy.

[~/kinetica-jupyterlab (master)]$ git clone https://chadjk@github.com/kineticadb/kinetica-jupyterlab.git
[~/kinetica-jupyterlab (master)]$ ls -l
total 16
-rw-r--r--@ 1 chadjuliano  staff  5809 Jul 25 14:33 README.md
drwxr-xr-x  8 chadjuliano  staff   256 Jul 25 13:58 docker
drwxr-xr-x  8 chadjuliano  staff   256 Jul 25 14:03 notebooks

The kinetica-jupyterlab/docker directory contains the scripts necessary to build and run the Docker image. The docker/share directory will be mounted as a volume in the image and contains configuration and persist data.

[~/kinetica-jupyterlab/docker (master)]$ ls -l
total 1311672
-rw-r--r--  1 chadjuliano  staff       2366 Jul 24 11:21 Dockerfile-jupyterlab-6.x
drwxr-xr-x  7 chadjuliano  staff        224 Jul 24 11:18 config
-rw-r--r--  1 chadjuliano  staff        551 Jul 24 11:20 docker-compose.yml
drwxr-xr-x  6 chadjuliano  staff        192 Jul 25 13:58 share

The kinetica-jupyterlab/notebooks directory contains notebooks and Python scripts needed to run them. This directory will also be mounted inside the image and its contents will be visible in JupyterLab.

[~/kinetica-jupyterlab/notebooks (master)]$ ls -l
total 0
drwxr-xr-x   5 chadjuliano  staff  160 Jul  6 21:56 Autoencoder
drwxr-xr-x  14 chadjuliano  staff  448 Jul 25 16:33 Examples
drwxr-xr-x   9 chadjuliano  staff  288 Jul 25 13:48 KJIO
drwxr-xr-x  13 chadjuliano  staff  416 Jul  9 09:32 SVD
drwxr-xr-x   8 chadjuliano  staff  256 Jul 24 18:42 UDF

In the kinetica-jupyterlab/notebooks/Examples directory are notebooks that demonstrate connectivity with Kinetica. Each is an interactive tutorial with its own documentation summarized below.

[table id=1 /]

The focus of this tutorial is to get you up and running with the Docker image so you can start exploring the notebooks. There may be follow up tutorials based on this environment to demonstrate more sophisticated ML use cases.

Pulling the Image

In this section we will use docker-compose to pull the kinetica/kinetica-jupyterlab image from DockerHub.

Open a shell to the Docker directory and invoke docker-compose pull. This will download about 7GB of data so make sure you have a solid internet connection.

[~/kinetica-jupyterlab (master)]$ cd docker/
[~/kinetica-jupyterlab/docker (master)]$ docker-compose pull
Pulling gpudb ... done

You can use the docker image command below to confirm your image was downloaded successfully.

[~/kinetica-jupyterlab/docker (master)]$ docker image list

REPOSITORY                      TAG              IMAGE ID              CREATED                     SIZE

kinetica/kinetica-jupyterlab    6.2              e9702b6e31fb          28 minutes ago              7.35GB

centos                          7                49f7960eb7e4          7 weeks ago                 200MB

Entering Your License Key

At this point you should have a Kinetica license key. If you do not already have a key, you can get one at https://www.kinetica.com/trial/.

# The license key to authorize running.
license_key = {your key}

The database is configured to start automatically, but for this to succeed a license key must be configured. Edit docker/share/conf/gpudb.conf, uncomment the line with license_key and add your key.

If the key is invalid then the container startup will fail.

Starting the Container

This tutorial uses docker-compose to manage the parameters of the container which can simplify things because all the settings are in the docker-compose.yml file.

Run the below docker-compose up command to start the image. The combined log output of Kinetica and JupyterLab will be displayed in the console. This console needs to be open for as long as the container is running.

[~/kinetica-jupyterlab/docker (master)]$ docker-compose up
Creating network "docker_default" with the default driver
Creating gpudb-jupyterlab-6.x ... done
Attaching to gpudb-jupyterlab-6.x
[...]
gpudb-jupyterlab-6.x | 2018-07-25 23:45:04.516 INFO  (2494,5923,r0/gpudb_sl_shtbl ) d0a1758a319b Utils/GaiaHTTPUtils.h:161 - JobId:1011; call_gaia_internal endpoint: /show/table completed in: 0.00193 s

If you want a bash prompt in the container, open up another console and run the below command.

[~/kinetica-jupyterlab/docker (master)]$ docker-compose exec gpudb /bin/bash
[root@d0a1758a319b ~]# su - gpudb
Last login: Wed Jul 25 23:44:11 UTC 2018
[gpudb@d0a1758a319b ~]$ 

To stop the container, use the docker-compose down command.

[~/kinetica-jupyterlab/docker (master)]$ docker-compose down
Stopping gpudb-jupyterlab-6.x ... done
Removing gpudb-jupyterlab-6.x ... done
Removing network docker_default

Exploring the Environment

To access to GAdmin open URL http://localhost:8080 and use login admin/admin.

To access JupyterLab open http://localhost:8888 and enter password kinetica. When you login you will see file browser on the left.

Navigate to the Examples folder and open notebook ex_kapi_io.ipynb. This notebook demonstrates basic interactions between Pandas dataframes and Kinetica via the functions in the KIJO module.

Select Kernel->Restart Kernel and Run All Cells… to clear the outputs. Then select the first cell and click the Play button to run each cell. Each notebook has a separate Python process or kernel that remembers the variables that were created when cells were executed. You can modify and re-execute any cell without starting from the beginning.

You can also open a Python console attached to the same kernel as a notebook. Right click on a cell and select New Console For Notebook. Enter one of the variables executed from the notebook (e.g. _test_df) and then press Shift+Enter to see the contents in the console.

You can access completions with Tab and tooltips with Shift+Tab.

Conclusion

The JupyterLab environment integrates many components. With it you can ingest an external data source, analyze it with some of the most powerful ML libraries, save the results to Kinetica, execute UDFs, and visualize the data all in a single notebook. You can add documentation and equations so your use case can tell a story to multiple audiences.

We hope you find this environment easy to use and productive for developing new use cases on the Kinetica platform. If you have any problems or questions please contact Chad Juliano <cjuliano@kinetica.com>.

As a next step you can run through the other example notebooks. Additional online resources are available here:

Chad is a Principal Consultant at Kinetica.