jupyter-kernel-mcp

jupyter-kernel-mcp

Enables AI agents to execute Python, TypeScript, and JavaScript code in persistent Jupyter kernels with stateful variables and imports across interactions.

Category
Visit Server

README

Jupyter Kernel MCP

PyPI version Python 3.10+ License: MIT

A Model Context Protocol (MCP) server that provides stateful Jupyter kernel development with multi-language support (Python, TypeScript, JavaScript) for AI agents and assistants.

Table of contents

  1. Project description
  2. Who this project is for
  3. Project dependencies
  4. Instructions for using Jupyter Kernel MCP
  5. Troubleshooting
  6. Contributing guidelines
  7. Additional documentation
  8. How to get help
  9. Terms of use

Project description

With Jupyter Kernel MCP you can execute Python, TypeScript, and JavaScript code in persistent, isolated environments that maintain state between executions—perfect for AI agents performing complex data analysis and development workflows.

Jupyter Kernel MCP helps you build stateful AI agent workflows that can load datasets, perform transformations, and analyze results across multiple interactions without losing variables or computed state.

Unlike traditional stateless code execution, Jupyter Kernel MCP preserves variables, imports, and computed results between AI agent messages, enabling sophisticated multi-step data science workflows.

Key Features

  • 🔄 Persistent State: Variables and imports persist between code executions
  • 🌐 Multi-Language Support: Python, TypeScript, and JavaScript kernels
  • 🚀 Multi-Kernel Support: Create and manage multiple isolated kernel environments
  • 🤖 AI-Agent Ready: Seamless integration with Claude Code and other MCP clients
  • 📊 Data Science Workflows: Perfect for iterative data analysis and exploration
  • ⚡ Fast Communication: Direct socket-based communication with Jupyter kernels
  • 🛠 Easy Management: Simple kernel lifecycle management (start, stop, reset, list)
  • 🔗 Unified API: Single interface for all languages - no separate tools needed

Who this project is for

This project is intended for AI developers, data scientists, and automation engineers who want to build intelligent agents that can perform stateful data analysis and complex computational workflows.

Perfect for:

  • Building AI agents that analyze datasets across multiple interactions
  • Creating persistent computational environments for LLMs
  • Developing stateful data science workflows with AI assistants
  • Prototyping and exploring APIs with maintained context
  • Full-stack development with TypeScript/JavaScript and Python
  • Educational environments teaching multiple programming languages

Project dependencies

Before using Jupyter Kernel MCP, ensure you have:

  • Python 3.10 or higher - Required for MCP SDK compatibility
  • Claude Code, Cline, or another MCP client - To interact with the server
  • Jupyter dependencies - Automatically installed with the package
  • Node.js (for TypeScript/JavaScript) - Required for TSLAB kernels (optional)
  • TSLAB - TypeScript/JavaScript kernel support (optional)

Instructions for using Jupyter Kernel MCP

Get started with Jupyter Kernel MCP by installing the package and adding it to your MCP client.

Install Jupyter Kernel MCP

From PyPI (Recommended)

Install using pip:

pip install jupyter-kernel-mcp

Or using uv:

uv add jupyter-kernel-mcp

From GitHub (Development Version)

To install the latest development version directly from GitHub:

uv tool install git+https://github.com/codewithcheese/jupyter-kernel-mcp.git

Verify Installation

jupyter-kernel-mcp --help

Optional: Install TSLAB for TypeScript/JavaScript Support

To enable TypeScript and JavaScript kernels:

# Install TSLAB globally
npm install -g tslab
# or with pnpm
pnpm install -g tslab

# Install kernel specs
tslab install

# Verify kernels are available
jupyter kernelspec list

You should see tslab and jslab in the kernel list.

Configure with Claude Code

  1. Add the server to Claude Code:

    claude mcp add jupyter-kernel jupyter-kernel-mcp
    
  2. Verify the server is listed:

    claude mcp list
    

Configure with other MCP clients

  1. Add to your MCP client configuration (example for mcp_config.json):

    {
      "servers": {
        "jupyter-kernel": {
          "command": "jupyter-kernel-mcp"
        }
      }
    }
    

Run Jupyter Kernel MCP

  1. The server starts automatically when called by your MCP client

    No manual startup required - the server launches when your MCP client connects.

  2. Start your first kernel:

    In Claude Code or your MCP client:

    Please start a new Jupyter kernel for data analysis
    
  3. Execute stateful code:

    Load this dataset and show me the first few rows:
    
    import pandas as pd
    df = pd.read_csv('data.csv')
    df.head()
    
  4. Continue the analysis in follow-up messages:

    Now group the data by category and calculate the mean values
    

    The df variable persists from the previous execution!

Available Tools

Tool Description
start_kernel Create a new Jupyter kernel for Python, TypeScript, or JavaScript
execute_code Execute code in any language kernel (auto-routes based on kernel type)
list_kernels Show all active kernels with their languages
list_variables Display variables in a kernel's namespace
get_kernel_status Get detailed kernel information
stop_kernel Stop and remove a specific kernel
reset_kernel Reset a kernel (clears all variables)

Troubleshooting

<table> <tr> <td><strong>Issue</strong></td> <td><strong>Solution</strong></td> </tr> <tr> <td>Server won't start - "No module named 'jupyter_client'"</td> <td>Install dependencies: <code>pip install jupyter-client</code></td> </tr> <tr> <td>Kernel creation fails</td> <td>Ensure Python 3.10+ is installed and accessible</td> </tr> <tr> <td>MCP client can't find server</td> <td>Verify installation: <code>which jupyter-kernel-mcp</code></td> </tr> <tr> <td>Variables not persisting between executions</td> <td>Ensure you're using the same kernel_id for related executions</td> </tr> <tr> <td>TypeScript/JavaScript kernel creation fails</td> <td>Install TSLAB: <code>npm install -g tslab && tslab install</code></td> </tr> <tr> <td>"tslab command not found" error</td> <td>Ensure Node.js is installed and TSLAB is in PATH</td> </tr> <tr> <td>TypeScript compilation errors</td> <td>Check TypeScript syntax - TSLAB uses strict type checking</td> </tr> </table>

Other troubleshooting resources:

  • Check server logs for detailed error messages
  • Verify your MCP client supports the required MCP protocol version
  • Ensure no firewall is blocking local kernel connections

Contributing guidelines

We welcome contributions! Please see our Contributing Guide for details on:

  • How to submit bug reports and feature requests
  • Development setup and testing procedures
  • Code style guidelines and review process

Additional documentation

For more information:

How to get help

Need assistance? Here's how to get support:

Terms of use

Jupyter Kernel MCP is licensed under the MIT License.


Built with ❤️ for the AI agent development community

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured