在VSCode环境下用dlv工具的attach模式远程调试在运行中的服务

本文详细介绍了在Ubuntu 20.04环境下,使用dlv工具进行非root用户Go程序远程调试的步骤,包括编译、启动、配置VSCode launch.json及注意事项,确保代码版本一致性。

一、前提条件

1、以下操作和注意事项都是基于ubuntu 20.04版本进行描述。
2、以下操作和注意事项都是基于操作系统的非root用户进行描述。
3、需要提前下载dlv工具,远程服务器上的dlv工具与本地dlv工具的版本要保持一致。
4、IDE基于vscode 1.63或更高版本进行描述。

二、操作流程

1、用下列命令编译代码

    go build -gcflags="all=-N -l" -o {二进制文件名称}

2、运行二进制文件

3、用下列命令查看PID

    ps -aux | grep {二进制文件名称}

4、用下列命令启动pid attach

    dlv --listen=:{port} --headless=true --api-version=2 attach {PID}

5、在vscode中创建launch.json文件,填入下列内容并保存

{
    // Use IntelliSense to learn about possible attributes.
    // Hover to view descriptions of existing attributes.
    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "remote debug",
            "type": "go",
            "request": "attach",
            "mode": "remote",
            "host": "192.168.50.223",
            "port": 2345,
            "cwd": "${workspaceFolder}"
        }
    ]
}

6、保存后点击vscode中run and debug的运行按钮(绿色三角按钮),会出现一个调试按钮的pannel,表示已经远程连接成功。此时就可以在本地对远端服务进行调试。

三、注意事项

1、采用非root用户进行操作,会出现权限问题无法进行pid attach,需要对/etc/sysctl.d/10-ptrace.conf配置文件进行修改。

    kernel.yama.ptrace_scope = 1   修改为  kernel.yama.ptrace_scope = 0 

2、点击调试pannel中红色的连接断开按钮,会使远端的dlv attach进程结束。如果要继续调试,需要在远端服务器执行上面操作流程中的步骤4

3、远端服务二进制所用代码的版本必须与本地代码的版本一致

     远端服务二进制所用代码的版本必须与本地代码的版本一致

     远端服务二进制所用代码的版本必须与本地代码的版本一致

     重要事情说三遍!!!

VSCode中不同场景下使用可视化调试器的方法如下: ### 调试Go程序 首先创建一个 `.vscode/launch.json` 的配置文件,示例配置如下: ```json { // 自定义名字 "name": "Launchfile", // 调试的程序类型 "type": "go", // 调试类型(调试二进制) "request": "launch", // 调试类型 "mode": "debug", // 调试的程序 "program": "${file}" } ``` 只要有二进制文件,就能使用这种类似 `dlv exec` 的方式进行调试 [^1]。 ### 远程单步调试设备(基于GDB+GDBSERVER) 对于嵌入式研发中Linux环境下开发工程师,可通过VSCode插件方式实现远程调试。首先要安装VSCODE必备插件 [^2]。 ### 可视化数据结构 安装扩展之后,打开相关脚本,导航到命令面板,进入 `Debug Visualizer: New View`。此视图可输入在单步执行代码时可视化的表达式,与VS代码的watch视图类似,区别在于结果是可视化而非文本格式显示 [^3]。 ### 调试Vue代码 1. 配置 `launch.json` 文件,`url` 与项目启动后的地址保持一致,示例配置如下: ```json { "version": "0.2.0", "configurations": [ { "type": "browser-preview", "request": "launch", "name": "Browser Preview: Launch", "url": "http://localhost:8080", "webRoot": "${workspaceFolder}/src", "sourceMapPathOverrides": { "webpack:///src/*": "${webRoot}/*", "webpack:///./src/*": "${webRoot}/*" } } ] } ``` 2. 配置项目 `vue.config.js`: ```javascript module.exports = { productionSourceMap: false, configureWebpack: { devtool: 'source-map' } // 或者下面这种方式 // configureWebpack: config => { // config.devtool = 'source-map'; // } }; ``` 3. 配置项目 `babel.config.js`: ```javascript module.exports = { env: { debug: { sourceMap: true, retainLines: true } }, // presets: ['@vue/app'] // @vue/cli-plugin-babel 3.x版本 presets: ['@vue/cli-plugin-babel/preset'] // @vue/cli-plugin-babel 4.x版本 }; ``` 4. 在项目 `js` 文件或 `vue` 文件左侧序号行打好断点 [^5]。 ### 连接远程服务器进行代码调试及可视化界面 若遇到一般无法选择conda虚拟环境、无法添加断点、`Ctrl + 鼠标左键` 无法跳转到代码模块等问题,只要在VSCode的扩展里安装Python扩展即可 [^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值