我有一个用golang编写的进程,它作为一个守护进程运行。
几天后,它没有明显的原因停止产量。我认为这可能是一个内部僵局。如果我做strace -p <PID>
我可以看到
futex(0x9aaba0, FUTEX_WAIT, 0, NULL
显然电话永远不会结束。我想使用已经运行的进程(因为我不知道如何/何时再次触发错误)来调试问题。
我怎样才能看到正在运行的goroutine以及它们在哪里?如何从进程中转储任何其他信息可能对调试问题有用?
答案 0 :(得分:11)
你可以向任何一个程序发送一个QUIT
信号,它将以完整的堆栈跟踪退出,显示所有goroutine的状态,以及它们是如何被阻止的。
至于strace
,go程序总是多线程的,所以你总是需要添加-f
选项