当前位置: 首页
编程语言
Ubuntu系统配置Python远程调试环境详细教程

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

热心网友 时间:2026-05-07
转载

在 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

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
防止未注册用户绕过登录直接访问系统的安全方法

防止未注册用户绕过登录直接访问系统的安全方法

一个经典的身份验证流程示例 在早期的Web应用开发中,实现一个基础的登录验证功能,其代码结构往往非常直观。下面这段经典的ASP代码片段,就清晰地展示了这一过程的核心逻辑。 登录验证:核对凭证 首先,系统会读取用户提交的账号和密码。这部分代码通常会放在登录处理页面(例如 Login asp):

时间:2026-05-07 12:46
XSL入门教程从零开始快速掌握

XSL入门教程从零开始快速掌握

一 XSL入门 1 XSL---XML的样式表 玩过HTML的朋友都知道,它有一套预设好的标签(tags),比如就是另起一行,就是标题字体。这套规则,所有浏览器都心知肚明,知道怎么解析和呈现。可到了XML这里,情况就完全不同了——它没有固定的标签!我们可以创建任何自己需要的标识。这样一来,问题就

时间:2026-05-07 12:46
FCKEditor内容获取字数统计与代码写入方法详解

FCKEditor内容获取字数统计与代码写入方法详解

FCKeditor前端开发实用代码片段 在Web开发中,Rich Text Editor (RTE) 的深度整合往往伴随一系列前端交互需求。今天,我们就来梳理几个围绕FCKeditor的实用Ja vaScript函数。这些代码片段能直接解决你在内容获取、动态编辑和状态控制上的常见问题。 1 获取格

时间:2026-05-07 12:46
Git分支删除操作步骤详解

Git分支删除操作步骤详解

一、删除本地分支 咱们先从本地操作说起。在Git里清理本地分支,通常是为了让工作区保持清爽,避免被一堆已经完成或废弃的分支干扰视线。整个流程可以分三步走,核心原则就一个:别在要删的分支上操作。 1 查看当前分支列表 动手之前,先看清楚战场。这个命令能列出你本地所有的分支,当前所在的分支前面会标一个星

时间:2026-05-07 12:45
Git回退后无法重新合并的解决方法与步骤详解

Git回退后无法重新合并的解决方法与步骤详解

问题背景 很多团队在使用码云企业版托管代码时,会采用经典的双分支模型:一个是受保护的 master 主线分支,另一个是用于日常开发的 dev 分支。保护分支的设置很常见,这意味着任何向 master 的合并都需要通过网页端发起合并请求并完成评审。 但实际操作中,难免会遇到这种情况:刚刚把 dev 的

时间:2026-05-07 12:45
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程