游乐游手机版
首页/编程语言/文章详情

Ubuntu系统配置Python远程调试环境详细教程

时间:2026-05-07 09:54
在 Ubuntu 上配置 Python 远程调试 当你的代码跑在远程服务器上,本地却想逐行“透视”它的执行过程时,远程调试就成了刚需。别担心,这事儿没想象中那么复杂。下面咱们就来聊聊几种主流方案,帮你打通本地与远程的调试通道。 方案一:VS Code + Remote-SSH + debugpy(推

在 Ubuntu 上配置 Python 远程调试

当你的代码跑在远程服务器上,本地却想逐行“透视”它的执行过程时,远程调试就成了刚需。别担心,这事儿没想象中那么复杂。下面咱们就来聊聊几种主流方案,帮你打通本地与远程的调试通道。

方案一:VS Code + Remote-SSH + debugpy(推荐组合)

这套组合堪称当前最流畅的远程调试体验之一,核心思路是利用 VS Code 强大的远程开发能力。

  • 本地安装 VS Code 扩展:首先,确保你的 VS Code 已经安装并启用了两个关键扩展:“Remote - SSH” 和 “Python”。
  • 建立 SSH 连接:点击 VS Code 左下角的绿色图标,选择 “Remote Explorer” → “SSH Targets: Add New SSH Host”。填入你的远程主机信息(格式如 user@remote_host),连接信息会保存到 ~/.ssh/config 文件中,之后便可一键连接远程 Ubuntu 环境。
  • 远程环境准备:连接成功后,重点来了——需要在远程主机上安装调试器。
    • 对于 Ubuntu 20.04 及以上版本,推荐使用:pip install -U debugpy
    • 如果你的旧项目还在使用老方案,可以安装:pip install ptvsd(这是旧版 VS Code 远程调试的常用库)。
  • 配置调试启动:有两种主流方式,可以根据你的习惯选择。
    • 方式 A:附加到已在运行的进程(推荐)
      1. 在远程的 Python 代码中(通常是入口文件或你需要打断点的模块顶部)插入以下代码:
        import debugpy
        debugpy.listen((“0.0.0.0”, 5678)) # 监听所有网络接口,端口号可自定义
        print(“Waiting for debugger attach…”)
        debugpy.wait_for_client() # 程序将在此阻塞,直到调试器连接
      2. 在本地 VS Code 项目中,创建或修改 .vscode/launch.json 文件,添加如下配置:
        {
            “version”: “0.2.0”,
            “configurations”: [{
                “name”: “Python: Remote Attach”,
                “type”: “python”,
                “request”: “attach”,
                “connect”: { “host”: “localhost”, “port”: 5678 },
                “pathMappings”: [{ “localRoot”: “${workspaceFolder}”, “remoteRoot”: “.” }]
            }]
        }
      3. 操作顺序:先在远程终端运行你的 Python 脚本,看到 “Waiting for debugger attach…” 提示后,再在 VS Code 中启动名为 “Python: Remote Attach” 的调试配置。
    • 方式 B:由 VS Code 直接启动并调试
      1. 在远程安装好 debugpy 后,在 VS Code 的 Python 解释器选择器中,切换到远程的 Python 环境。
      2. launch.json 中,使用 “request”: “launch” 的配置,指定程序入口文件和参数,必要时可以设置 “console”: “integratedTerminal”
  • 网络与权限
    • 如果 VS Code 和 Ubuntu 服务器不在同一台机器上,需要确保远程监听的端口(例如 5678)能够被本地访问到。对于云服务器,记得在安全组规则中放行该端口;内网环境则可以直接连接。
    • 在生产或多人协作环境下,强烈建议配置 SSH 密钥登录,避免反复输入密码,既安全又便捷。
  • 说明
    • 网上一些旧教程使用的 ptvsd,其配置思路和 debugpy 基本一致。但对于新项目,优先推荐使用 debugpy,它能获得更好的支持和性能。

方案二:Docker 容器中的远程调试

如果你的应用运行在 Docker 容器内,调试同样可以安排。思路是将容器视为一个微型远程主机。

  • 启动容器并映射端口与目录:运行容器时,需要映射 SSH 端口(例如 22)和你的代码目录。
    docker run --gpus all -it --name tf2 -p 1234:22 -v /home/you/project:/home/project tensorflow/tensorflow:latest-gpu /bin/bash
  • 容器内配置 SSH 服务:进入容器后,需要安装并启动 SSH 服务。
    • 更新包列表并安装:apt-get update && apt-get install -y openssh-server
    • 编辑 SSH 配置以允许 root 登录:vim /etc/ssh/sshd_config,设置 PermitRootLogin yes
    • 启动服务:service ssh start
    • 为 root 用户设置一个密码:passwd
  • VS Code 配置
    • 在 VS Code 的 SSH 配置文件中添加容器主机信息(示例):
      Host tf2
          HostName <服务器IP>
          Port 1234
          User root
    • 使用 Remote-SSH 连接这个名为 “tf2” 的主机,之后的选择远程解释器、创建调试会话等步骤,就完全和方案一一样了。只需确保端口映射和代码路径映射正确无误。

方案三:终端远程调试工具备选

对于没有图形界面的纯终端环境,或者需要快速排查的生产服务器,这些基于命令行的调试工具非常实用。

  • pudb(全屏终端可视化调试器,支持远程)
    • 安装:pip install pudb
    • 远程调试方法:
      • 在代码中设置断点:from pudb.remote import set_trace; set_trace(host=“0.0.0.0”, port=5555)
      • 在另一台机器的终端中使用:telnet <远程IP> 5555 进行连接和调试。
  • rpdb(基于 socket 的远程 pdb)
    • 安装:pip install rpdb
    • 远程调试方法:
      • 在代码中设置断点:import rpdb; rpdb.set_trace(addr=“0.0.0.0”, port=4444)
      • 使用 netcat 连接:nc <远程IP> 4444
  • 适用场景:这类工具特别适合在无图形界面的服务器上进行快速问题定位。当然,使用前务必记得在防火墙或安全组中开放对应的调试端口,并做好访问控制。

常见问题与排错要点

调试之路难免遇到小坎坷,以下几个关键点帮你快速排雷:

  • 端口连通性
    • 云服务器用户,请首先检查安全组规则是否放行了调试端口。一个简单的测试命令是:nc -vz <端口>
  • 路径映射
    • 在 VS Code 的 launch.json 中,pathMappings 配置至关重要。它建立了本地工作区与远程项目根目录的对应关系,如果配错,断点将无法命中。
  • 解释器选择
    • 使用 Remote-SSH 连接后,务必在 VS Code 的 Python 扩展中选择远程的 Python 解释器,否则依赖解析和调试环境会发生错位。
  • 旧版依赖
    • 如果项目仍在使用 ptvsd,建议逐步迁移到 debugpy。两者的附加(Attach)配置思路是相通的,迁移成本不高。
  • REPL 与交互
    • 通过 debugpy 附加调试时,本地的调试控制台并不会直接变成远程的 REPL。如果需要交互式命令行,可以打开 VS Code 的 Remote-SSH 集成终端,或者连接远程的 Jupyter 服务器来执行交互式代码。
来源:https://www.yisu.com/ask/96094853.html
上一篇Ubuntu系统Python脚本运行报错解决方法详解 下一篇Ubuntu系统安装配置Python机器学习库教程
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
Java日期字符串格式化:指定样式转换教程
编程语言 · 2026-07-05

Java日期字符串格式化:指定样式转换教程

Java 日期字符串格式转换:从 "yyyy-MM-dd " 到 "dd-MM-yyyy " 并保留纳秒精度 日期格式转换是 Java 日常开发中非常常见的需求。然而,看似简单的操作一旦忽略了细节,就容易埋下隐患。本文主要介绍如何将类似 "2023-03-13 12:00:02 " 的字符串,转换为 "1

Java static方法优雅替换全局配置管理
编程语言 · 2026-07-05

Java static方法优雅替换全局配置管理

在Java项目中,“能否用static方法替代全局配置管理”几乎是每次技术讨论都会出现的话题。答案是:可以,但前提是掌握正确用法。static方法本身并非配置管理的替代品,它更像一个统一入口——将散布在各处的硬编码值集中管理,封装成一个受控、只读、可验证的配置访问点。 真正优雅的做法是:利用stat

Java抽象类约束子类行为实现标准规范
编程语言 · 2026-07-05

Java抽象类约束子类行为实现标准规范

在Java的世界里,抽象类(Abstract Class)是约束子类行为最经典的机制之一。它既不像接口那样仅做纯声明,也不像普通类那样提供完整实现——它处于两者之间,既是契约也是骨架。核心要点就是:在父类中使用abstract关键字声明抽象方法,编译器会自动检查,漏掉一个方法都无法通过编译。 抽象类

Java多线程环境下StringBuffer字符串拼接方法
编程语言 · 2026-07-05

Java多线程环境下StringBuffer字符串拼接方法

StringBuffer 的线程安全机制,实质上是在所有修改方法上添加了 synchronized 锁——例如 append、insert、delete 等操作,均受同一把 this 锁保护。同一时刻只允许一个线程对内部的 char[] 数组和 count 字段进行修改,从而保障数据一致性。但代价显

Java局部变量作用域冲突解决与实战指南
编程语言 · 2026-07-05

Java局部变量作用域冲突解决与实战指南

Ja va局部变量作用域冲突:本质是设计问题,靠工具不如靠思路 许多开发者遇到局部变量与成员变量同名时,第一反应可能是“编译器会自动处理吧?”——遗憾的是,Ja va编译器仅负责报告语法错误,并不会替你梳理业务逻辑。局部变量作用域冲突本质上属于逻辑边界设计问题,必须由开发者主动规划、显式隔离。核心方