vs code jupyter连gpu结点kernel

学校的服务器 [1] 分登录结点和计算结点。以往想在 jupyter notebook 调用 GPU 跑程序,是用 ssh tunnel 转发到自己电脑,然后用浏览器打开。

现发现直接在 VS Code 中用 jupyter notebook 更好用,但遇到一个问题:在给 notebook 选 kernel 时,如果用 Jupyter Kernel...,则会选中登录结点的 kernel,从而无法使用计算结点的 GPU:

Fig. 1

因为我 vs code 是连去登录结点,而不是直接连计算结点。此时正确的选法是用 Existing Jupyter Server... 指定用从计算结点启动的 jupyter lab server。

Steps

假设已装好 python、jupyterlab,配过 jupyter 密码,且配好一个虚拟环境叫 env1

  1. 注测 kernel

    shell 复制代码
    conda activate env1
    pip install ipykernel # 如之前未装过
    python -m ipykernel install --user --name=env1 --display-name="超人 (迪迦)"

    此时如果按图 1 点 Jupyter Kernel...,应能看见刚创建的这个「超人 (迪迦)」kernel(可能要 vs code 重连才刷新出来)。但选这个 kernel 会用登录结点的 python。

  2. 在计算结点启动 jupyter lab server:

    shell 复制代码
    # 在计算结点上
    conda activate env1 # 激活 jupyter lab 所在虚拟环境
    jupyter lab # 启动

    一串输出中包含:

    复制代码
    (...其它...)
    [I 2025-11-09 16:10:21.531 ServerApp] Jupyter Server 2.14.1 is running at:
    [I 2025-11-09 16:10:21.531 ServerApp] http://localhost:8888/lab
    (...其它...)

    表明 jupyter lab 的端口是 8888

  3. vs code 创建 notebook:此时 vs code 是远程连去学校登录结点(中某个代码目录)的,在 vs code 界面中 Ctrl + Shift + P 呼出命令界面,打 Create: New Jupyter Notebook 就能创建;再 Ctrl + S 保存、顺便给 notebook 起名。

  4. 选 kernel:在 notebook 界面,如图 1,「Select Kernel」->「Existing Jupyter Server...」(而不是「Jupyte Kernel...」),然后就让输入 server 的 URL(图 2),写:http://1.2.3.4:8888,其中 1.2.3.4 是计算结点的 IP,8888 是 jupyter 端口。回车让输 jupyter 密码(图 3);再回车让输 display name,随意;又回车,让选 kernel,此时应该也能看到刚才注册的「超人 (迪迦)」,选它。

Fig. 2
Fig. 3

这个 kernel 就可以用计算结点的 GPU 了。可在 notebook 内执行:

  • !nvidia-smi
  • import torch; torch.cuda_is_available()

验证。

References

  1. 用UTS gpu集群
  2. Save Remote Server Password #13671
相关推荐
前端若水20 分钟前
【无标题】
java·人工智能·python·机器学习
databook1 小时前
填充与积累:积分与面积的可视化
python·数学·动效
TechWayfarer1 小时前
AI大模型时代:IP数据云如何适配智能体场景需求
开发语言·人工智能·python·网络协议·tcp/ip·langchain
Ysn07191 小时前
中文乱码:在 Docker 容器中设置中文语言环境
运维·python·docker·容器
qingfeng154151 小时前
企业微信消息监听实战:如何实时接收客户消息回调?
人工智能·python·自动化·企业微信
晚霞的不甘2 小时前
CANN Catlass 矩阵乘模板库深度解析:高性能矩阵运算的进阶之路
人工智能·python·线性代数·矩阵
小白学大数据2 小时前
深度探索:Python 爬虫实现豆瓣音乐全站采集
开发语言·爬虫·python·数据分析
用户6757049885022 小时前
Celery 太重了?这可能是你一直在找的 asyncio 任务队列
后端·python·消息队列