猿问

无法调试 Go 代码:无法启动进程:在偏移量 0x0 处解码矮节信息:太短

我们正在尝试调试 Go 代码并收到此错误:


could not launch process: decoding dwarf section info at offset 0x0: too short

我们的设置:


WITSC02X6385JGH:orderer sjain68$ uname -a

Darwin WITSC02X6385JGH 17.7.0 Darwin Kernel Version 17.7.0: Fri Jul  6 19:54:51 PDT 2018; root:xnu-4570.71.3~2/RELEASE_X86_64 x86_64

WITSC02X6385JGH:orderer sjain68$ go version

go version go1.11 darwin/amd64

WITSC02X6385JGH:orderer sjain68$ dlv version

Delve Debugger

Version: 1.1.0

Build: $Id: 1990ba12450cab9425a2ae62e6ab988725023d5c

我们尝试过的事情:


使用 VS Code 更新 dlv -> Go: Install/Update Tools

尝试从命令行运行:


WITSC02X6385JGH:orderer sjain68$ /Users/sjain68/go/bin/dlv debug github.com/hyperledger/fabric/orderer --headless=true --listen=127.0.0.1:41305 --api-version=2 --log=true --

API server listening at: 127.0.0.1:41305

INFO[0002] launching process with args: [/Users/sjain68/go/src/github.com/hyperledger/fabric/orderer/debug]  layer=debugger

debugserver-@(#)PROGRAM:debugserver  PROJECT:debugserver-902.0.79.7

 for x86_64.

Got a connection, launched process /Users/sjain68/go/src/github.com/hyperledger/fabric/orderer/debug (pid = 9278).

Exiting.

could not launch process: decoding dwarf section info at offset 0x0: too short

请注意,我们尝试调试的二进制文件确实被执行了。只是调试器没有启动。


我们通过此尝试的另一件事:


WITSC02X6385JGH:orderer sjain68$ export GOFLAGS="-ldflags=-compressdwarf=false"; dlv debug

could not launch process: decoding dwarf section info at offset 0x0: too short

有人说要运行 GOCACHE=off go build ... 


我们如何解决这个问题?


九州编程
浏览 246回答 3
3回答

墨色风雨

更新 Go 后我遇到了同样的问题。从控制台更新 Delve 包有帮助:go get -u github.com/go-delve/delve/cmd/dlv

梦里花落0921

确保您没有使用从构建中删除调试信息的标志,即 -ldflags="-s -w" 。

牛魔王的故事

对我们有用的解决方案是升级 Go 版本$ go versiongo version go1.13.3 darwin/amd64所以 Go 1.11 是罪魁祸首。
随时随地看视频慕课网APP

相关分类

Go
我要回答