Skip to main content

JupyterLite extension to connect to a remote Jupyter server

Project description

jupyterlite-remote-server

Github Actions Status

A JupyterLite extension that connects to a remote Jupyter server for all services (kernels, contents, terminals, etc.).

This extension replaces JupyterLite's in-browser service implementations with standard JupyterLab service managers that communicate with a remote Jupyter server. This allows you to run a static JupyterLite frontend while using a real Jupyter server for all backend operations.

How It Works

The extension provides ServiceManagerPlugins that:

  1. Provide standard JupyterLab service managers configured to connect to a remote server
  2. Read server connection settings dynamically from PageConfig
  3. Provide a vendored theme manager that reads theme assets from a configurable URL

The corresponding JupyterLite in-browser service plugins must be disabled via jupyter-lite.json configuration (see Usage with JupyterLite).

Configuration

Configure the extension by setting these options in jupyter-lite.json.

Default Configuration (All Services)

These options apply to all services unless overridden by service-specific options:

Option Description
remoteBaseUrl The base URL of the remote Jupyter server (e.g., http://localhost:8888/)
remoteToken The authentication token for the remote server
appendToken Whether to append token to WebSocket URLs. If not set, auto-detects based on whether the base URL and WebSocket URL are on the same host

Theme Configuration

Option Description
fullThemesUrl The full URL to the themes directory (e.g., http://localhost:8080/build/themes). Used by the vendored theme manager plugin to load theme CSS from the JupyterLite server instead of joining baseUrl with paths.

Service-Specific Configuration (Optional)

You can configure different URLs and tokens for specific service groups. If not specified, services fall back to the default remoteBaseUrl and remoteToken.

Option Services Affected Description
remoteContentsBaseUrl Contents, Default Drive Base URL for file operations
remoteContentsToken Contents, Default Drive Token for file operations
remoteKernelsBaseUrl Kernels, Kernel Specs, Sessions Base URL for kernel operations
remoteKernelsToken Kernels, Kernel Specs, Sessions Token for kernel operations
remoteTerminalsBaseUrl Terminals Base URL for terminals
remoteTerminalsToken Terminals Token for terminals
remoteEventsBaseUrl Events Base URL for server events
remoteEventsToken Events Token for server events
remoteNbconvertBaseUrl NbConvert Base URL for notebook conversion
remoteNbconvertToken NbConvert Token for notebook conversion
remoteConfigSectionBaseUrl Config Sections Base URL for config sections
remoteConfigSectionToken Config Sections Token for config sections

Usage with JupyterLite

1. Start the Jupyter Server

Start a Jupyter server with CORS enabled to allow connections from JupyterLite:

jupyter server --ServerApp.token=my-token --ServerApp.allow_origin='*'

2. Create JupyterLite Configuration

Create a jupyter-lite.json configuration file.

Basic Configuration (Single Server)

Use the default options when all services connect to the same server:

{
  "jupyter-lite-schema-version": 0,
  "jupyter-config-data": {
    "remoteBaseUrl": "http://localhost:8888/",
    "remoteToken": "my-token",
    "fullThemesUrl": "http://localhost:8080/build/themes",
    "disabledExtensions": [
      "@jupyterlite/services-extension:config-section-manager",
      "@jupyterlite/services-extension:default-drive",
      "@jupyterlite/services-extension:event-manager",
      "@jupyterlite/services-extension:exporters",
      "@jupyterlite/services-extension:kernel-manager",
      "@jupyterlite/services-extension:kernel-client",
      "@jupyterlite/services-extension:kernel-spec-client",
      "@jupyterlite/services-extension:kernel-spec-manager",
      "@jupyterlite/services-extension:kernel-specs",
      "@jupyterlite/services-extension:nbconvert-manager",
      "@jupyterlite/services-extension:session-manager",
      "@jupyterlite/application-extension:service-worker-manager",
      "@jupyterlab/apputils-extension:themes"
    ]
  }
}

Advanced Configuration (Multiple Servers)

Use service-specific options when different services need to connect to different servers:

{
  "jupyter-lite-schema-version": 0,
  "jupyter-config-data": {
    "remoteBaseUrl": "http://localhost:8888/",
    "remoteToken": "default-token",
    "remoteContentsBaseUrl": "http://files-server:8889/",
    "remoteContentsToken": "files-token",
    "remoteKernelsBaseUrl": "http://compute-server:8890/",
    "remoteKernelsToken": "compute-token",
    "fullThemesUrl": "http://localhost:8080/build/themes",
    "disabledExtensions": [
      "@jupyterlite/services-extension:config-section-manager",
      "@jupyterlite/services-extension:default-drive",
      "@jupyterlite/services-extension:event-manager",
      "@jupyterlite/services-extension:exporters",
      "@jupyterlite/services-extension:kernel-manager",
      "@jupyterlite/services-extension:kernel-client",
      "@jupyterlite/services-extension:kernel-spec-client",
      "@jupyterlite/services-extension:kernel-spec-manager",
      "@jupyterlite/services-extension:kernel-specs",
      "@jupyterlite/services-extension:nbconvert-manager",
      "@jupyterlite/services-extension:session-manager",
      "@jupyterlite/application-extension:service-worker-manager",
      "@jupyterlab/apputils-extension:themes"
    ]
  }
}

In this example:

  • File operations (contents) use http://files-server:8889/
  • Kernel operations (kernels, sessions, kernel specs) use http://compute-server:8890/
  • All other services fall back to the default http://localhost:8888/

3. Build and Serve JupyterLite

pip install jupyterlite-core jupyterlite-remote-server
jupyter lite build
cd _output
python -m http.server 8080

Then open http://localhost:8080/lab/ in your browser.

Demo

The demo/ directory contains a complete working example with separate servers for contents and kernels. To run it locally:

# Install the demo dependencies
pip install -r demo/requirements.txt

# Build the JupyterLite site
cd demo
jupyter lite build

Then start three terminals:

# Terminal 1 — Jupyter server for contents and other services
jupyter server --port=8888 --ServerApp.token=my-token --ServerApp.allow_origin='*'

# Terminal 2 — Jupyter server for kernels
jupyter server --port=7777 --ServerApp.token=kernels-token --ServerApp.allow_origin='*'

# Terminal 3 — JupyterLite frontend
cd demo/_output
python -m http.server 8080

Open http://localhost:8080/lab/ in your browser.

Plugins Provided

This extension provides the following ServiceManagerPlugins:

Plugin Token Service Type Description
server-settings IServerSettings default Remote server connection settings
default-drive IDefaultDrive contents Server-connected file drive
contents-manager IContentsManager contents File contents management
kernel-manager IKernelManager kernels Kernel lifecycle management
kernel-spec-manager IKernelSpecManager kernels Kernel specifications with URL rewriting
session-manager ISessionManager kernels Session management
event-manager IEventManager events Server events
config-section-manager IConfigSectionManager configSection Config section management
nbconvert-manager INbConvertManager nbconvert Notebook conversion
terminal-manager ITerminalManager terminals Terminal sessions
themes IThemeManager Vendored theme manager reading fullThemesUrl from PageConfig

Disabled Extensions

The following JupyterLite and JupyterLab plugins must be disabled in jupyter-lite.json to avoid conflicts with the plugins provided by this extension:

Disabled Extension Reason
@jupyterlite/services-extension:config-section-manager Replaced by this extension's config-section-manager
@jupyterlite/services-extension:default-drive Replaced by this extension's default-drive
@jupyterlite/services-extension:event-manager Replaced by this extension's event-manager
@jupyterlite/services-extension:exporters Not needed with a remote server
@jupyterlite/services-extension:kernel-manager Replaced by this extension's kernel-manager
@jupyterlite/services-extension:kernel-client Not needed with a remote server
@jupyterlite/services-extension:kernel-spec-client Not needed with a remote server
@jupyterlite/services-extension:kernel-spec-manager Replaced by this extension's kernel-spec-manager
@jupyterlite/services-extension:kernel-specs Not needed with a remote server
@jupyterlite/services-extension:nbconvert-manager Replaced by this extension's nbconvert-manager
@jupyterlite/services-extension:session-manager Replaced by this extension's session-manager
@jupyterlite/application-extension:service-worker-manager Not needed with a remote server
@jupyterlab/apputils-extension:themes Replaced by this extension's vendored themes plugin

Requirements

  • JupyterLab >= 4.0.0
  • A running Jupyter server with CORS enabled

Install

pip install jupyterlite-remote-server

Uninstall

pip uninstall jupyterlite-remote-server

Contributing

Development install

# Clone the repo and change to the directory
git clone https://github.com/jtpio/jupyterlite-remote-server.git
cd jupyterlite-remote-server

# Set up a virtual environment
python -m venv .venv
source .venv/bin/activate

# Install in development mode
pip install --editable "."
jupyter labextension develop . --overwrite

# Rebuild after making changes
jlpm build

Development with watch mode

# Watch the source directory (in one terminal)
jlpm watch

# Run JupyterLab (in another terminal)
jupyter lab

Development uninstall

pip uninstall jupyterlite_remote_server

Then remove the symlink from jupyter labextension list location named jupyterlite-remote-server.

Packaging

See RELEASE

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

jupyterlite_remote_server-0.2.0.tar.gz (98.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jupyterlite_remote_server-0.2.0-py3-none-any.whl (21.4 kB view details)

Uploaded Python 3

File details

Details for the file jupyterlite_remote_server-0.2.0.tar.gz.

File metadata

File hashes

Hashes for jupyterlite_remote_server-0.2.0.tar.gz
Algorithm Hash digest
SHA256 73a795dd7c492e119e85cce13dd6a9ae88c19b70b9dcea39d00b785d701c9d09
MD5 d5229aa94dc323c98e46802e68117f82
BLAKE2b-256 d48741ae68bdf29687ded6673c57f952afcf2de6b31754c9b02f6c680ed5fac9

See more details on using hashes here.

File details

Details for the file jupyterlite_remote_server-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyterlite_remote_server-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d5f68d53c2c90f1f79e69805abf2d6af8a22c1d7716659b7e8f0301536da9f0e
MD5 c75cae9702f94bc662bfed3ec01044d5
BLAKE2b-256 ed2e882ff85d563fc07f51957bed4acf678ff9f78f5d57c1063bba16324b855e

See more details on using hashes here.

Supported by

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