Skip to main content

JupyterHub Spawner for Kubernetes (Rubin asyncio version)

Project description

kubespawner (jupyterhub-kubespawner @ PyPI)

Documentation status GitHub Workflow Status Code coverage

The kubespawner (also known as JupyterHub Kubernetes Spawner) enables JupyterHub to spawn single-user notebook servers on a Kubernetes cluster.

See the KubeSpawner documentation for more information about features and usage. In particular, here is a list of all the spawner options.

Features

Kubernetes is an open-source system for automating deployment, scaling, and management of containerized applications. If you want to run a JupyterHub setup that needs to scale across multiple nodes (anything with over ~50 simultaneous users), Kubernetes is a wonderful way to do it. Features include:

  • Easily and elasticly run anywhere between 2 and thousands of nodes with the same set of powerful abstractions. Scale up and down as required by simply adding or removing nodes.

  • Run JupyterHub itself inside Kubernetes easily. This allows you to manage many JupyterHub deployments with only Kubernetes, without requiring an extra layer of Ansible / Puppet / Bash scripts. This also provides easy integrated monitoring and failover for the hub process itself.

  • Spawn multiple hubs in the same kubernetes cluster, with support for namespaces. You can limit the amount of resources each namespace can use, effectively limiting the amount of resources a single JupyterHub (and its users) can use. This allows organizations to easily maintain multiple JupyterHubs with just one kubernetes cluster, allowing for easy maintenance & high resource utilization.

  • Provide guarantees and limits on the amount of resources (CPU / RAM) that single-user notebooks can use. Kubernetes has comprehensive resource control that can be used from the spawner.

  • Mount various types of persistent volumes onto the single-user notebook's container.

  • Control various security parameters (such as userid/groupid, SELinux, etc) via flexible Pod Security Policies.

  • Run easily in multiple clouds (or on your own machines). Helps avoid vendor lock-in. You can even spread out your cluster across multiple clouds at the same time.

In general, Kubernetes provides a ton of well thought out, useful features - and you can use all of them along with this spawner.

Requirements

Kubernetes

Everything should work from Kubernetes v1.6+.

The Kube DNS addon is not strictly required - the spawner uses environment variable based discovery instead. Your kubernetes cluster will need to be configured to support the types of volumes you want to use.

If you are just getting started and want a kubernetes cluster to play with, Google Container Engine is probably the nicest option. For AWS/Azure, kops is probably the way to go.

Getting help

We encourage you to ask questions on the Jupyter mailing list. You can also participate in development discussions or get live help on Gitter.

License

We use a shared copyright model that enables all contributors to maintain the copyright on their contributions.

All code is licensed under the terms of the revised BSD license.

Resources

JupyterHub and kubespawner

Jupyter

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rubin-kubespawner-2.0.1.dev1.tar.gz (49.9 kB view details)

Uploaded Source

Built Distribution

rubin_kubespawner-2.0.1.dev1-py2.py3-none-any.whl (50.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file rubin-kubespawner-2.0.1.dev1.tar.gz.

File metadata

  • Download URL: rubin-kubespawner-2.0.1.dev1.tar.gz
  • Upload date:
  • Size: 49.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.10

File hashes

Hashes for rubin-kubespawner-2.0.1.dev1.tar.gz
Algorithm Hash digest
SHA256 ab4ba6bd25f251399fe4c863b3809d5b75f3056e9f87b0a7bf5134384c14f333
MD5 1a0b405f43cdca64a41b9233437a813a
BLAKE2b-256 bc1ab19901243c9e4b5fdcdfd596c9fed54e2eb7252f2247c698f1f44daa451f

See more details on using hashes here.

File details

Details for the file rubin_kubespawner-2.0.1.dev1-py2.py3-none-any.whl.

File metadata

  • Download URL: rubin_kubespawner-2.0.1.dev1-py2.py3-none-any.whl
  • Upload date:
  • Size: 50.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.10

File hashes

Hashes for rubin_kubespawner-2.0.1.dev1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ad3fa1bdad769ef95ad9223368e9049145c5cd1a358884f0b98d894043aacfef
MD5 f6f2b6171a31d2466c46041f479f0b3c
BLAKE2b-256 901c2b6599b7230d7bcce44d22f23c99d5df6f849005825e7d4a90eb8e63b229

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page