jupyterhub/wrapspawner

Name: wrapspawner

Owner: JupyterHub

Description: Mechanism for runtime configuration of spawners for JupyterHub

Created: 2016-09-21 21:48:31.0

Updated: 2017-12-20 09:53:17.0

Pushed: 2017-12-18 15:28:01.0

Homepage:

Size: 96

Language: Python

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

wrapspawner for Jupyterhub

Build Status

This package includes WrapSpawner and ProfilesSpawner, which provide mechanisms for runtime configuration of spawners. The inspiration for their development was to allow users to select from a range of pre-defined batch job profiles, but their operation is completely generic.

Installation
  1. From root directory of this repo (where setup.py is), run pip install -e .

    If you don't actually need an editable version, you can simply run:

    pip install git+https://github.com/jupyterhub/wrapspawner

  2. Add lines in jupyterhub_config.py for the spawner you intend to use, e.g.

    = get_config()
    JupyterHub.spawner_class = 'wrapspawner.ProfilesSpawner'
    
  3. Depending on the spawner, additional configuration will likely be needed.

Wrapper and Profile Spawners
Overview

WrapSpawner provides a mechanism to wrap the interface of a JupyterHub Spawner such that the Spawner class to use for single-user servers can be chosen dynamically. Subclasses may modify the class or properties of the child Spawner at any point before start() is called (e.g. from Authenticator pre_spawn hooks or options form processing) and that state will be preserved on restart. The start/stop/poll methods are not real coroutines, but simply pass through the Futures returned by the wrapped Spawner class.

ProfilesSpawner leverages JupyterHub's Spawner “options form” feature to allow user-driven configuration of Spawner classes while permitting:

Example

Here is a screenshot of a typical dropdown menu letting the user choose between several SLURM instances:

The following configuration snippet lets the user choose between a Jupyter server running as a local process or one of two different Docker Images to run within DockerSpawner.

.JupyterHub.spawner_class = 'wrapspawner.ProfilesSpawner'
.Spawner.http_timeout = 120
------------------------------------------------------------------------------
 ProfilesSpawner configuration
------------------------------------------------------------------------------
 List of profiles to offer for selection. Signature is:
   List(Tuple( Unicode, Unicode, Type(Spawner), Dict ))
 corresponding to profile display name, unique key, Spawner class,
 dictionary of spawner config options.
 
 The first three values will be exposed in the input_template as {display},
 {key}, and {type}

c.ProfilesSpawner.profiles = [
      ( "Host process", 'local', 'jupyterhub.spawner.LocalProcessSpawner', {'ip':'0.0.0.0'} ),
      ('Docker Python 2/3', 'systemuser', 'dockerspawner.SystemUserSpawner', dict(container_image="jupyterhub/systemuser")),
      ('Docker Python 2/3,R,Julia', 'datasciencesystemuser', 'dockerspawner.SystemUserSpawner', dict(container_image="jupyterhub/datasciencesystemuser")),
]
History

These mechanisms originated as part of the batchspawner package. The batchspawner README contains additional examples on the use of ProfilesSpawner.


This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.