您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > Go语言

Go 的 Debug 工具 delve 介绍

时间:2020-06-26 15:37:10  来源:  作者:

以下文章来源于大愚Talk ,作者大愚Talk

delve 的汉语意思是:钻研、探索;用这个来命名一个debug工具还是非常的形象。

本文主要介绍该工具的安装与常用使用方法。是一个step-by-step的文章。目标是帮助大家学会如何使用 delve 来debug自己的代码。

安装

官网的安装文档地址:
https://github.com/go-delve/delve/tree/master/Documentation/installation

我再重复下如何在 mac 上进行安装。

首先 xcode-select --install 把依赖的编译工具链安装一下。

然后通过下面的命令即可完成

$ go get github.com/go-delve/delve/cmd/dlv

这里有个注意点,大家如果使用modules的方式来管理项目,应该知道安装依赖包也是上面这个命令。所以执行上面的命令时,请确保自己不是在一个go modules的路径下。

到此,安装工作就可以完成了,可以在终端执行,可以看到如下画面:

➜ /Users/dayu >dlv version
Delve Debugger
Version: 1.4.0
Build: $Id: 67422e6f7148fa1efa0eac1423ab5594b223d93b $

命令介绍

用中文来翻译下命令的含义。

Usage:
  dlv [command]

Available Commands:
  attach      可以用来对一个正在运行的进行进行调试.
  connect     连接到headless调试器.
  core        用来调试core文件.
  dap         [EXPERIMENTAL] 启动一个Debug Adaptor Protocol (DAP)的TCP服务器来通信.
  debug       在当前包或者指定的包编译并debug程序.
  exec        如果你已经编译好了二进制,可以用该命令启动调试.
  help        帮助命令.
  test        可以用来测试自己编写的测试源码文件.
  trace       编译并跟踪程序.

dlv 的命令非常多,主要介绍下 debug 与 attach 的使用。其它命令大家可以尝试下,不过一般用的也非常少!dlv test 这个也非常有用,不过使用跟debug差不多。

使用

下面将主要介绍这 debug 与 attach 如何使用,这两个命令其实主要面对两种使用场景。

  1. 用 Golang 写了一个命令行程序,想要debug一下;
  2. 写了一个 Grpc 或者 Http 服务,运行的进行进行debug;

进入调试后,他们的命令非常相似,下面开始我们的 debug 之旅。

Debug Main包程序

先来看直接使用 debug 来调试代码。调试的代码样例:

Go 的 Debug 工具 delve 介绍

 

debug调试代码

此时在终端进入该文件所在路径,然后执行

dlv debug

然后会成功进入 delve 提供的debug交互界面,如下图所示。

Go 的 Debug 工具 delve 介绍

 

debug交互

图中展示了三个非常常用的命令。来分别解释下。

  • b main.main

这个命令的全拼是:break main.main 用来设置断点的。除了这种写法,常用的还有使用行号来设置断点 b 9。

  • bp

这个命令是用来查找已经设置的断点的。

Go 的 Debug 工具 delve 介绍

 

断点查看

查看已经设置的断点常常一个目的是用来寻找 clear 可以清除哪一个断点。

  • c

该命令是让程序运行起来。遇到设置的断点会停止。


上面只是非常基础的三个命令,我们再来继续往下走。继续看这张执行示例图

Go 的 Debug 工具 delve 介绍

 

调试

这张图中的命令,都是非常常用的调试命令,来一起看看作用

  • restart

这个命令的主要作用就是一轮debug完成了,重新开始下一轮,上一次设置的断点会依然有效

  • n

这是执行下一步,也就是代码的下一行。它就是一行一行的往下,不会陷入内部去

  • s

该命令注意与 n 的区别,它是进入某个函数的内部,源码函数也能够跟踪进去,非常有利于我们学习。但是对于 goroutine 执行的函数你是无法进入的。这也很好理解,因为它的执行时机不可知。

  • p

这个是debug过程中非常重要的一个命令,打印变量的值。也是学习 go 语言的一个利器,图中可以看到一个 channel 初始化之后的内部结构体。这对我们理解源码非常有帮助。


下面的命令图中没有演示,但觉得有必要说一下。

  • so

如果用了 s 陷入到内部函数,可以快速使用该命令跳出来,回到进入点。

  • gr and grs

这两个命令是用来查看 groutine 的。

他还有非常多的命令。我们可以在使用过程中随时使用 help 来进行查看。文末我也放了一张所有命令图的翻译。

Debug运行的进程

对于运行中的进程,主要说明下如何进入 debug 交互界面,进入后的操作与上面是一样的。

假如我们有一个 http 的进程在运行,看一下如何进行 debug。示例代码如下:

func main() {
	http.HandleFunc("/", Hello)

	http.ListenAndServe(":8080", nil)
}

func Hello(w http.ResponseWriter, r *http.Request) {
	a := "test"

	fmt.Println(a)

	time.Sleep(3 * time.Second)

	fmt.Fprint(w, "Hello World")
}

将这个 demo 给运行起来,然后找到他的进程号。执行下面的命令:

dlv attach {pid}

这个 pid 就是当前进程的进程号。

使用该方式要注意:设置完断点后记得用 c 让进程处于运行状态,否则对于 http 或者 grpc 的程序,没有办法继续接受请求,进而无法进入测试。

Go 的 Debug 工具 delve 介绍

 

参考资料

[1] https://github.com/go-delve/delve



Tags:Go Debug   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
delve 的汉语意思是:钻研、探索;用这个来命名一个debug工具还是非常的形象。...【详细内容】
2020-06-26  Tags: Go Debug  点击:(59)  评论:(0)  加入收藏
▌简易百科推荐
zip 是一种常见的归档格式,本文讲解 Go 如何操作 zip。首先看看 zip 文件是如何工作的。以一个小文件为例:(类 Unix 系统下)$ cat hello.textHello!执行 zip 命令进行归档:$ zip...【详细内容】
2021-12-17  Go语言中文网    Tags:Go语言   点击:(13)  评论:(0)  加入收藏
大家好,我是 polarisxu。前段时间,Russ Cox 明确了泛型相关的事情,原计划在标准库中加入泛型相关的包,改放到 golang.org/x/exp 下。目前,Go 泛型的主要设计者 ianlancetaylor 完...【详细内容】
2021-11-30  Go语言中文网    Tags:slices 包   点击:(24)  评论:(0)  加入收藏
前言最近因为项目需要写了一段时间的 Go ,相对于 Java 来说语法简单同时又有着一些 Python 之类的语法糖,让人大呼”真香“。 但现阶段相对来说还是 Python 写的多一些,偶尔还...【详细内容】
2021-11-25  crossoverJie    Tags:Go   点击:(29)  评论:(0)  加入收藏
go-micro是基于 Go 语言用于开发的微服务的 RPC 框架,主要功能如下:服务发现,负载均衡 ,消息编码,请求/响应,Async Messaging,可插拔接口,最后这个功能牛p安装步骤安装proto...【详细内容】
2021-09-06    石老师小跟班  Tags:go-micro   点击:(197)  评论:(0)  加入收藏
GoLand 2021.2 EAP 5 现已发布。用户可以从工具箱应用程序中获得 EAP 构建,也可以从官方网站手动下载。并且从此 EAP 开始,只有拥有有效的 JetBrains 帐户才能加入该计划。手...【详细内容】
2021-06-29  IT实战联盟  今日头条  Tags:GoLand   点击:(185)  评论:(0)  加入收藏
作者:HDT3213今天给大家带来的开源项目是 Godis:一个用 Go 语言实现的 Redis 服务器。支持: 5 种数据结构(string、list、hash、set、sortedset) 自动过期(TTL) 发布订阅、地理位...【详细内容】
2021-06-18  HelloGitHub  今日头条  Tags:Go   点击:(125)  评论:(0)  加入收藏
统一规范篇合理规划目录本篇主要描述了公司内部同事都必须遵守的一些开发规矩,如统一开发空间,既使用统一的开发工具来保证代码最后的格式的统一,开发中对文件和代码长度的控制...【详细内容】
2021-05-18  1024课堂    Tags:Go语言   点击:(232)  评论:(0)  加入收藏
闭包概述 闭包不是Go语言独有的概念,在很多编程语言中都有闭包 闭包就是解决局部变量不能被外部访问的一种解决方案 是把函数当作返回值的一种应用 代码演示总体思想:在函数...【详细内容】
2021-05-14  HelloGo  今日头条  Tags:Go语言   点击:(223)  评论:(0)  加入收藏
一时想不开,想了解一下Go语言,于是安装了并体验了一下。下载1. 进入golang.google.cn 点击Download Go 2.选择对应的操作系统,点击后开始下载。 安装1. windows下执行傻瓜式安...【详细内容】
2021-05-12  程序员fearlazy  fearlazy  Tags:Go语言   点击:(236)  评论:(0)  加入收藏
1.简介channel是Go语言的一大特性,基于channel有很多值得探讨的问题,如 channel为什么是并发安全的? 同步通道和异步通道有啥区别? 通道为何会阻塞协程? 使用通道导致阻塞的协程...【详细内容】
2021-05-10  程序员麻辣烫  今日头条  Tags:Go通道   点击:(274)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条