ea5c94cdb9
It is not directly related to signal-handling, so can well live in its own package. Also added a variant that doesn't take a directory to write files to, for easier consumption / better match to how it's used. Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
27 lines
562 B
Go
27 lines
562 B
Go
// +build !windows
|
|
|
|
package daemon // import "github.com/docker/docker/daemon"
|
|
|
|
import (
|
|
"os"
|
|
"os/signal"
|
|
|
|
"github.com/docker/docker/pkg/stack"
|
|
"github.com/sirupsen/logrus"
|
|
"golang.org/x/sys/unix"
|
|
)
|
|
|
|
func (daemon *Daemon) setupDumpStackTrap(root string) {
|
|
c := make(chan os.Signal, 1)
|
|
signal.Notify(c, unix.SIGUSR1)
|
|
go func() {
|
|
for range c {
|
|
path, err := stack.DumpToFile(root)
|
|
if err != nil {
|
|
logrus.WithError(err).Error("failed to write goroutines dump")
|
|
} else {
|
|
logrus.Infof("goroutine stacks written to %s", path)
|
|
}
|
|
}
|
|
}()
|
|
}
|