123456789101112131415161718192021222324252627282930313233 |
- // +build !windows
- package daemon
- import (
- "os"
- "os/signal"
- "syscall"
- "github.com/Sirupsen/logrus"
- stackdump "github.com/docker/docker/pkg/signal"
- )
- func (d *Daemon) 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")
- } else {
- logrus.Infof("goroutine stacks written to %s", path)
- }
- path, err = d.dumpDaemon(root)
- if err != nil {
- logrus.WithError(err).Error("failed to write daemon datastructure dump")
- } else {
- logrus.Infof("daemon datastructure dump written to %s", path)
- }
- }
- }()
- }
|