VSCode - debug运行在docker 容器里的nodejs

1. 在docker中暴露出端口9229

9229是nodejs默认的debug端口

1.1 docker-compose.yml 文件的ports中需要添加

services:
  mockit-routes:
    image: 'mockit-routes'
    build: 'mockit-routes'
    ports:
      - 3000:3000
      - "9229:9229"
    volumes:
      - ./configuration/routes.json:/usr/src/mockit-routes/configuration/routes.json
      

或者docker run 的时候添加 -p 9229:9229

docker run -d -p 3000:3000 -p 9229:9229 node:15.0.1-alpine

1.2  修改Dockerfile文件, 多暴露出9229端口

EXPOSE 3000 9229

2.修改npm运行命令

修改Dockerfile 文件的命令

CMD ["npm", "run", "debug"]

对应的package.json里面的scripts 

"scripts": {
    "debug": "node --inspect=0.0.0.0:9229 src/index",
  },

// src/index 为要debug的js

3.生成launch.json文件

 修改launch.json文件

{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Docker: Attach to Node",
      "type": "node",
      "request": "attach",
      "restart": true,
      "port": 9229,
      "address": "localhost",
      "localRoot": "${workspaceFolder}",
      "remoteRoot": "/usr/src/mockit-routes",   //对应Dockerfile 里面的路径
      "protocol": "inspector"
    }
  ]
}

4. 运行

启动docker,vscode中点击Run and Debug

查看docker 容器日志, 有如下log即为debug上了

Debugger listening on ws://0.0.0.0:9229/38be2bc8-d92d-41cb-b238-750d3d2e7147
For help, see: https://nodejs.org/en/docs/inspector
Debugger attached.

浏览器访问 localhost:3000

接下来就可以随心所欲的debug了

注意: 我的docker 暴露出两个端口3000, 9229  浏览器访问的时候是3000, debug是9229,

这两个端口不能一致,Web 服务器和调试器是独立的服务器, 不能使用同一个端口 否则会报错WebSockets request was expected(调试器是内置在 node.js 运行时中的服务器)。

 

### 回答1: VS Code是一款非常流行的开发工具,它提供了丰富的功能和插件来支持远程调试。在使用VS Code进行远程调试docker中的node.js应用程序时,我们需要进行以下几个步骤。 首先,我们需要在docker容器中安装VS Code Server。我们可以通过运行以下命令将VS Code Server添加到我们的Dockerfile中: ``` RUN apt-get update && \ apt-get install -y curl && \ curl -fsSL https://code-server.dev/install.sh | sh ``` 然后,我们需要设置docker容器的端口映射,将VS Code Server的端口映射到主机的一个端口上。我们可以使用以下命令来运行docker容器: ``` docker run -d -p 8080:8080 -v "$(pwd):/home/coder/project" my-node-app ``` 这个命令将容器中的端口8080映射到主机的端口8080上,并将当前目录挂载到容器中的`/home/coder/project`目录中。 接下来,我们需要在VS Code中安装Remote - Containers插件。我们可以在VS Code的插件商店中搜索并安装该插件。 安装成功后,我们可以在VS Code的底部状态栏找到一个绿色的“><”图标。点击该图标,然后选择“Remote-Containers: Attach to Running Container”选项。 在弹出的菜单中,我们可以选择我们之前运行docker容器。选择后,VS Code将会连接到docker容器,并在VS Code的界面中打开一个新的窗口。 在VS Code中,我们可以打开我们的node.js项目,并在需要的位置设置断点。然后,我们可以使用VS Code的调试功能来启动我们的程序,并进行远程调试。我们可以点击VS Code界面左侧的调试图标,然后选择我们的调试配置并点击“启动调试”按钮。 此时,VS Code将会与我们的程序建立远程连接,并在断点处停下。我们可以使用VS Code的调试工具来查看变量的值、单步调试等操作。 通过以上步骤,我们成功地在VS Code中实现了远程调试docker中的node.js应用程序。使用VS Code的强大调试功能,我们可以更方便地进行代码调试和错误排查。 ### 回答2: 要在VSCode中远程调试Docker中的Node.js应用程序,需要按照以下步骤进行设置和配置。 首先,确保已经在本地安装了VSCodeDocker。 1. 在本地的VSCode中安装"Remote - Containers"插件。这个插件可以让我们连接到Docker容器中的开发环境。 2. 在Docker中设置你的Node.js应用程序。可以在Dockerfile中指定要使用的基础镜像,并将Node.js应用程序复制到容器中。 3. 创建一个名为".devcontainer"的目录,并在其中创建一个名为"devcontainer.json"的文件。在这个文件中,可以指定要使用的Docker镜像和连接到容器时要运行的命令。 4. 在"devcontainer.json"文件中,你还需要配置"ports"选项,以便将容器中的端口映射到本地。通过指定要映射的本地端口和容器内部的端口号,可以让VSCode在本地打开容器中的应用程序。 5. 在VSCode中,按下Ctrl + Shift + P,然后选择"Remote-Containers: Open Folder in Container",然后选择项目文件夹。VSCode将会连接到Docker容器。 6. 在VSCode中打开你的Node.js应用程序的调试视图。点击左侧的调试按钮,然后点击配置按钮,选择Node.js环境。 7. 在VSCode中的调试视图中,点击启动按钮。VSCode将连接到Docker容器中的Node.js应用程序,并开始远程调试。 通过按照上述步骤设置和配置,你就可以在VSCode中远程调试Docker中的Node.js应用程序了。这样,你就可以在本地编写和调试代码,同时在Docker容器运行和测试应用程序。 ### 回答3: 使用VSCode进行远程调试Docker中的Node.js应用可以通过以下几个步骤完成。 首先,确保你的机器上安装了VSCodeDocker,并且Docker已经成功安装并运行。 其次,在VSCode中安装Remote Development扩展。这个扩展提供了远程开发的功能,并且可以与Docker集成。 接下来,在你的终端或命令行工具中,使用Docker运行你的Node.js应用。使用适当的Docker命令和参数,将你的应用程序容器化,并确保容器对外暴露了Node.js应用程序的调试端口。 然后,打开VSCode并进入扩展的Remotes视图。点击“Attach to Running Container”按钮,并选择你的Node.js应用程序的Docker容器。 接下来,在VSCode的调试视图中,点击“添加配置”按钮,并选择Node.js环境。在生成的launch.json配置文件中,确保指定了正确的远程主机和调试端口。 最后,点击“启动调试”按钮,VSCode将会连接到你的Docker容器,并开始调试你的Node.js应用程序。你可以在VSCode中设置断点、查看变量和调试输出,就像在本地开发环境一样。 总结起来,通过这些步骤,你可以很方便地使用VSCodeDocker中的Node.js应用进行远程调试,提高开发效率和调试能力。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值