Jupyter MCP Server
通过模型上下文协议启用与 Jupyter Notebook 的交互,支持在 JupyterLab 环境中执行代码和插入 Markdown。
README
<!--
~ Copyright (c) 2023-2024 Datalayer, Inc.
~
~ BSD 3-Clause License
-->
[](https://datalayer.io)
[](https://github.com/sponsors/datalayer)
# 🪐 ✨ Jupyter MCP 服务器
[](https://github.com/datalayer/jupyter-mcp-server/actions/workflows/build.yml)
[](https://pypi.org/project/jupyter-mcp-server)
[](https://smithery.ai/server/@datalayer/jupyter-mcp-server)
Jupyter MCP 服务器是一个 [模型上下文协议](https://modelcontextprotocol.io) (MCP) 服务器实现,它提供与在任何 JupyterLab 中运行的 📓 Jupyter 笔记本的交互(也适用于您的 💻 本地 JupyterLab)。

## 启动 JupyterLab
确保您已安装以下组件。 需要 collaboration 包,因为笔记本上所做的修改可以通过 [Jupyter 实时协作](https://jupyterlab.readthedocs.io/en/stable/user/rtc.html) 看到。
```bash
pip install jupyterlab jupyter-collaboration ipykernel
pip uninstall -y pycrdt datalayer_pycrdt
pip install datalayer_pycrdt
然后,使用以下命令启动 JupyterLab。
jupyter lab --port 8888 --IdentityProvider.token MY_TOKEN --ip 0.0.0.0
您也可以运行 make jupyterlab。
[!NOTE]
--ip设置为0.0.0.0,以允许在 Docker 容器中运行的 MCP 服务器访问您的本地 JupyterLab。
与 Claude Desktop 一起使用
可以从此页面下载适用于 macOS 和 Windows 的 Claude Desktop。
对于 Linux,我们成功使用了这个基于 nix 的非官方构建脚本
# ⚠️ 非官方
# 您也可以运行 `make claude-linux`
NIXPKGS_ALLOW_UNFREE=1 nix run github:k3d3/claude-desktop-linux-flake \
--impure \
--extra-experimental-features flakes \
--extra-experimental-features nix-command
要将其与 Claude Desktop 一起使用,请将以下内容添加到您的 claude_desktop_config.json 中(在 MCP 文档网站 上阅读更多信息)。
[!IMPORTANT]
确保
SERVER_URL和TOKEN的端口与jupyter lab命令中使用的端口匹配。
NOTEBOOK_PATH应该相对于 JupyterLab 启动的目录。
macOS 和 Windows 上的 Claude 配置
{
"mcpServers": {
"jupyter": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"SERVER_URL",
"-e",
"TOKEN",
"-e",
"NOTEBOOK_PATH",
"datalayer/jupyter-mcp-server:latest"
],
"env": {
"SERVER_URL": "http://host.docker.internal:8888",
"TOKEN": "MY_TOKEN",
"NOTEBOOK_PATH": "notebook.ipynb"
}
}
}
}
Linux 上的 Claude 配置
CLAUDE_CONFIG=${HOME}/.config/Claude/claude_desktop_config.json
cat <<EOF > $CLAUDE_CONFIG
{
"mcpServers": {
"jupyter": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"SERVER_URL",
"-e",
"TOKEN",
"-e",
"NOTEBOOK_PATH",
"--network=host",
"datalayer/jupyter-mcp-server:latest"
],
"env": {
"SERVER_URL": "http://localhost:8888",
"TOKEN": "MY_TOKEN",
"NOTEBOOK_PATH": "notebook.ipynb"
}
}
}
}
EOF
cat $CLAUDE_CONFIG
组件
工具
该服务器目前提供 3 个工具:
add_execute_code_cell
- 在 Jupyter 笔记本中添加并执行代码单元格。
- 输入:
cell_content(string): 要执行的代码。
- 返回:单元格输出。
add_markdown_cell
- 在 Jupyter 笔记本中添加一个 markdown 单元格。
- 输入:
cell_content(string): Markdown 内容。
- 返回:成功消息。
-
download_earth_data_granules⚠️ 我们计划将来将此工具迁移到单独的存储库,因为它特定于地理空间分析。
- 在 Jupyter 笔记本中添加一个代码单元格,以下载来自 NASA Earth Data 的地球数据颗粒。
- 输入:
folder_name(string): 用于保存数据的本地文件夹名称。short_name(string): 要下载的地球数据集的简称。count(int): 要下载的数据颗粒的数量。temporal(tuple): (可选) 格式为 (date_from, date_to) 的时间范围。bounding_box(tuple): (可选) 格式为 (lower_left_lon, lower_left_lat, upper_right_lon, upper_right_lat) 的边界框。
- 返回:单元格输出。
构建
您可以从源代码构建 Docker 镜像。
make build-docker
通过 Smithery 安装
要通过 Smithery 自动为 Claude Desktop 安装 Jupyter MCP 服务器:
npx -y @smithery/cli install @datalayer/jupyter-mcp-server --client claude
推荐服务器
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
mcp-server-qdrant
这个仓库展示了如何为向量搜索引擎 Qdrant 创建一个 MCP (Managed Control Plane) 服务器的示例。
AIO-MCP Server
🚀 集成了 AI 搜索、RAG 和多服务(GitLab/Jira/Confluence/YouTube)的一体化 MCP 服务器,旨在增强 AI 驱动的开发工作流程。来自 Folk。
https://github.com/Streen9/react-mcp
react-mcp 与 Claude Desktop 集成,能够根据用户提示创建和修改 React 应用程序。
MCP Atlassian
适用于 Atlassian Cloud 产品(Confluence 和 Jira)的 Model Context Protocol (MCP) 服务器。此集成专为 Atlassian Cloud 实例设计,不支持 Atlassian Server 或 Data Center 部署。
any-chat-completions-mcp
将 Claude 与任何 OpenAI SDK 兼容的聊天完成 API 集成 - OpenAI、Perplexity、Groq、xAI、PyroPrompts 等。
MySQL MCP Server
允许人工智能助手通过受控界面列出表格、读取数据和执行 SQL 查询,从而使数据库探索和分析更安全、更有条理。
browser-use MCP server
一个由人工智能驱动的浏览器自动化服务器,它实现了模型上下文协议,从而能够使用自然语言控制网页浏览器,以执行诸如导航、表单填写和视觉交互等任务。
mcp-codex-keeper
作为开发知识的守护者,为 AI 助手提供精心策划的最新文档和最佳实践访问权限。