dlv attach 出现恐慌:<nil>不是 Int

dlv attach got panic: <nil> not an Int

提问人:fio 提问时间:6/9/2023 更新时间:6/10/2023 访问量:199

问:

当我安装 dlv 并尝试附加 pid 时,我感到恐慌:

dlv attach 1
panic: <nil> not an Int

goroutine 1 [running]:
go/constant.Int64Val(0x0, 0x0, 0xc, 0xc0074ff300)
        /usr/local/go/src/go/constant/value.go:499 +0x19d
github.com/go-delve/delve/pkg/proc.(*Variable).parseG.func1(0xba0c52, 0xc, 0x9)
        /home/go/src/delve/pkg/proc/variables.go:822 +0x6b
github.com/go-delve/delve/pkg/proc.(*Variable).parseG(0xc0074fe200, 0xc000244000, 0xc0074fe200, 0x0)
        /home/go/src/delve/pkg/proc/variables.go:846 +0x44b
github.com/go-delve/delve/pkg/proc.GetG(0xcb1b60, 0xc000244000, 0xc000244000, 0x7fb53c4fe2a8, 0xc000228580)
        /home/go/src/delve/pkg/proc/variables.go:247 +0xd1
github.com/go-delve/delve/pkg/proc.NewTarget(0xcb4760, 0xc000228580, 0xc000051840, 0x1a, 0xc000212420, 0x1, 0x1, 0xc00016e520, 0x200, 0xc0001cb6b8, ...)
        /home/go/src/delve/pkg/proc/target.go:128 +0x22d
github.com/go-delve/delve/pkg/proc/native.(*nativeProcess).initialize(0xc000228580, 0xc000051840, 0x1a, 0xc000212420, 0x1, 0x1, 0x0, 0xc0002688c0, 0x10000c0001cb750)
        /home/go/src/delve/pkg/proc/native/proc.go:305 +0x19e
github.com/go-delve/delve/pkg/proc/native.Attach(0x1, 0xc000212420, 0x1, 0x1, 0xc0001cb898, 0xc0001cb7a0, 0x40bb0b)
        /home/go/src/delve/pkg/proc/native/proc_linux.go:132 +0x1bb
github.com/go-delve/delve/service/debugger.(*Debugger).Attach(0xc0002146c0, 0x1, 0x0, 0x0, 0xc0001cb858, 0x1, 0x1)
        /home/go/src/delve/service/debugger/debugger.go:295 +0x216
github.com/go-delve/delve/service/debugger.New(0xc0002687e0, 0xc000212560, 0x0, 0x0, 0x0, 0x0, 0x0)
        /home/go/src/delve/service/debugger/debugger.go:121 +0x7cd
github.com/go-delve/delve/service/rpccommon.(*ServerImpl).Run(0xc000214600, 0xc000214600, 0xc00024e5a0)
        /home/go/src/delve/service/rpccommon/server.go:112 +0xc8
github.com/go-delve/delve/cmd/dlv/cmds.execute(0x1, 0xc000212560, 0x0, 0x0, 0xc000245f80, 0x0, 0x0, 0x3, 0x0)
        /home/go/src/delve/cmd/dlv/cmds/commands.go:774 +0x501
github.com/go-delve/delve/cmd/dlv/cmds.attachCmd(0xc000238900, 0xc000212560, 0x1, 0x1)
        /home/go/src/delve/cmd/dlv/cmds/commands.go:606 +0xc0
github.com/spf13/cobra.(*Command).execute(0xc000238900, 0xc000212510, 0x1, 0x1, 0xc000238900, 0xc000212510)
        /home/go/pkg/mod/github.com/spf13/[email protected]/command.go:647 +0x231
github.com/spf13/cobra.(*Command).ExecuteC(0xc0002386c0, 0xc0002386c0, 0xb99853, 0x6)
        /home/go/pkg/mod/github.com/spf13/[email protected]/command.go:733 +0x2bc
github.com/spf13/cobra.(*Command).Execute(...)
        /home/go/pkg/mod/github.com/spf13/[email protected]/command.go:692
main.main()
        /home/go/src/delve/cmd/dlv/main.go:24 +0xc6

我是如何安装的: wget https://studygolang.com/dl/golang/go1.14.1.linux-amd64.tar.gz

tar -C /usr/local -zxvf go1.14.1.linux-amd64.tar.gz

  mkdir -p /home/go/bin/home/go/pkg /home/go/src

  vi .bash_profile

  source .bash_profile 

14 cd $GOPATH/src/

15 git 克隆 https://github.com/derekparker/delve.git

16 cd delve/cmd/dlv/

18 去构建

19 去安装

DLV 版本 Delve 调试器 版本: 1.4.0 内部版本: $Id: 67422e6f7148fa1efa0eac1423ab5594b223d93b $

我不知道如何解决它

恐慌 DLV

评论

0赞 Marijn 6/9/2023
你真的用过pid 1吗?这个 pid 通常是一些核心系统进程,例如在我的机器上,它是由 root 创建的。当然,如果给出更多的描述性错误会很好,但我想它只是未能附加到该进程,因为它不是它旨在附加的进程。Go 程序的“真实”pid 更有可能是四位数或更多。systemddlv
0赞 fio 6/9/2023
是的,我敢肯定是 1。它部署在 k8s 容器上。我通过 ps -ef 得到了 pid

答:

0赞 fio 6/10/2023 #1

我已经找到了解决方案。版本太旧了: https://github.com/go-delve/delve/issues/3133 最新的 dlv 运行良好。