0

0

VS Code中调试Docker容器内运行的应用

P粉986688829

P粉986688829

发布时间:2025-12-04 20:37:37

|

341人浏览过

|

来源于php中文网

原创

VS Code 调试 Docker 容器内应用需容器暴露调试端口、应用以调试模式监听 0.0.0.0、正确配置 launch.json 的 attach 或 Remote-Containers 方式,并注意源码路径映射与网络绑定细节。

vs code中调试docker容器内运行的应用

在 VS Code 中调试 Docker 容器内的应用,核心是让调试器连接到容器中运行的进程(比如 Node.js、Python 或 .NET 应用),而不是直接在宿主机上启动。关键在于:容器需暴露调试端口、启用调试模式、并配置 VS Code 的 launch.json 正确转发或直连。

确保容器内应用支持远程调试

不同语言的调试方式不同,但共性是:应用必须以“调试模式”启动,并监听一个可被外部访问的端口(通常是 localhost:922956785005 等)。

  • Node.js:启动命令加 --inspect=0.0.0.0:9229(注意用 0.0.0.0 而非 127.0.0.1,否则容器内 localhost 无法被外部访问)
  • Python(使用 debugpy):在代码开头插入 import debugpy; debugpy.listen(("0.0.0.0", 5678)),并确保已安装 debugpy
  • .NET Core:用 dotnet run --configuration Debug --no-launch-profile --launch-profile "" 并配合 vsdbg 镜像或容器内安装调试器

正确暴露和映射调试端口

Docker 默认隔离网络,必须显式发布调试端口,且避免仅用 -p 9229:9229 就完事——某些调试协议(如 Chrome DevTools Protocol)需要额外端口或 WebSocket 支持。

  • 运行容器时加 -p 9229:9229(Node)、-p 5678:5678(Python)等
  • 若调试器依赖文件系统映射(如断点源码路径),建议挂载源码目录:-v $(pwd):/app,并确保容器内工作目录与本地一致
  • 对于 Node.js,推荐加 --inspect-brk 实现启动即暂停,方便 VS Code 在第一行就介入

配置 VS Code 的 launch.json

不依赖 Docker 扩展也能调试,但推荐使用官方 Docker 扩展 + Remote - Containers 扩展实现更无缝体验。两种主流方式:

企业信使2.0
企业信使2.0

企业信使是一个集多种短信业务功能和管理功能于一体的短信服务多功能运营平台,具有稳定可靠、模块化、开放性、灵活性等特点,它既适用于各行业企业集团做行业短信信应用(集团客户),也适合于短信信第五媒体运营公司(短信信媒体业务公司)对外提供服务运营。平台支持内容提供商(CP)或集团客户的合作,如短信互动业务;手机报新闻服务;气象台、票中心、交警提供信资讯服务;商场开展客户调查及促销活动等等;同时支持媒体公

下载
  • 方式一:Attach 到运行中的容器
    适用于已启动的容器。在 .vscode/launch.json 中添加 attach 类型配置,指定端口、地址(通常为 localhost)、以及源码映射(localRoot / remoteRoot)。例如 Node.js:
{
  "type": "node",
  "request": "attach",
  "name": "Attach to Docker",
  "port": 9229,
  "address": "localhost",
  "localRoot": "${workspaceFolder}",
  "remoteRoot": "/app",
  "skipFiles": ["/**"]
}
  • 方式二:Remote-Containers 开发容器
    打开文件夹 → 按 Ctrl+Shift+P → “Remote-Containers: Reopen in Container”,VS Code 会自动构建/启动容器,并在容器内运行整个编辑器后端。此时调试就像在本地一样自然,无需手动 attach。

常见问题排查

连不上?大概率卡在这几个点:

  • 容器内应用没真正监听 0.0.0.0(只监听 127.0.0.1localhost)→ 查看进程绑定:netstat -tuln | grep 9229
  • 防火墙或 Docker Desktop 设置阻止端口映射 → 检查 docker ps 输出中 PORTS 列是否显示 0.0.0.0:9229->9229/tcp
  • 源码路径不匹配导致断点灰掉 → 严格核对 localRootremoteRoot,尤其注意路径结尾斜杠和大小写
  • Python debugpy 启动后未调用 debugpy.wait_for_client() → 若加了 --wait-for-client 参数,代码需主动等待

基本上就这些。调试 Docker 内应用不复杂,但容易忽略网络绑定和路径映射这两个细节。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

420

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

536

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

312

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

842

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

746

2023.11.06

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

842

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

746

2023.11.06

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

8

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
2022大前端凭啥拿高薪?
2022大前端凭啥拿高薪?

共6课时 | 2.1万人学习

PHP代码整洁之道
PHP代码整洁之道

共7课时 | 7.1万人学习

http状态码大全
http状态码大全

共47课时 | 107.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号