dlv使用技巧小记

dlv命令说明:delve/README.md at master · go-delve/delve · GitHub

如何确定文件完整路径

在使用break时,在经过公司流水线编译后,一般不能方便的拿到源代码文件路径(locspec),比如用于类型转换的工具包"github.com/spf13/cast"内的"cast.go"源代码文件在编译后的路径就变成了"/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/cast.go",其中如何获取前半部分"/tmp/go-build1662448535/pkg/mod/",阻塞了我好一会。

解决:使用sources命令

dlv attach 12345
(dlv) sources
/usr/local/go1.18.3/src/bufio/bufio.go
/usr/local/go1.18.3/src/bufio/scan.go
/usr/local/go1.18.3/src/bytes/buffer.go
/usr/local/go1.18.3/src/bytes/bytes.go
/usr/local/go1.18.3/src/bytes/reader.go
...(dlv) sources cast
/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/cast.go
/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/caste.go
/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/timeformattype_string.go

你的项目可能有很多package、go文件,sources 后可跟正则,可以更快的查找

某个dlv命令输出太多,标准输出放不下

我最开始使用sources命令时,没注意到sources后可以跟正则,执行sources后输出数据行数有2k+,看了下help发现 transcript 这个命令,它可以将各个命令的输出写到指定文件中

(dlv) transcript -x /home/xxx/debug/sources
(dlv) sources
(dlv) transcript -off

其中-x是标准输出就不打印了,收集完数据后,记得 transcript -off关掉

输出字符串限制

通过config -list 可以查看可以配置的选项,其中 max-string-len可以配置输出的最大字符串长度,可以根据自身情况合理设置该值