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
可以配置输出的最大字符串长度,可以根据自身情况合理设置该值
版权声明:本文为qq_35362055原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。