如何调试用golang编写的死锁进程

时间:2015-02-24 08:52:15

标签: go

我有一个用golang编写的进程,它作为一个守护进程运行。

几天后,它没有明显的原因停止产量。我认为这可能是一个内部僵局。如果我做strace -p <PID>我可以看到

futex(0x9aaba0, FUTEX_WAIT, 0, NULL
显然电话永远不会结束。我想使用已经运行的进程(因为我不知道如何/何时再次触发错误)来调试问题。

我怎样才能看到正在运行的goroutine以及它们在哪里?如何从进程中转储任何其他信息可能对调试问题有用?

1 个答案:

答案 0 :(得分:11)

你可以向任何一个程序发送一个QUIT信号,它将以完整的堆栈跟踪退出,显示所有goroutine的状态,以及它们是如何被阻止的。

至于strace,go程序总是多线程的,所以你总是需要添加-f选项