Files
docker-cli/components/engine/daemon/debugtrap_unix.go
Alexander Morozov f5432a5e82 daemon: always dump stack to file
Dumping to log is unusable in 90% of cases and inspecting file is much
more convenient.

Signed-off-by: Alexander Morozov <lk4d4@docker.com>
Upstream-commit: e5d36586acdd020a0a6d5840ea1fd060b6e3504b
Component: engine
2016-11-02 11:22:43 -07:00

29 lines
506 B
Go

// +build !windows
package daemon
import (
"os"
"os/signal"
"syscall"
stackdump "github.com/docker/docker/pkg/signal"
"github.com/Sirupsen/logrus"
)
func setupDumpStackTrap(root string) {
c := make(chan os.Signal, 1)
signal.Notify(c, syscall.SIGUSR1)
go func() {
for range c {
path, err := stackdump.DumpStacks(root)
if err != nil {
logrus.WithError(err).Error("failed to write goroutines dump")
continue
}
logrus.Infof("goroutine stacks written to %s", path)
}
}()
}