Browse Source

[bugfix] Fix interrupt hook overwritten bug

pull/747/head
Alex Wang 6 years ago
parent
commit
4db68669b6
  1. 1
      weed/util/pprof.go
  2. 25
      weed/util/signal_handling.go

1
weed/util/pprof.go

@ -14,7 +14,6 @@ func SetupProfiling(cpuProfile, memProfile string) {
glog.Fatal(err) glog.Fatal(err)
} }
pprof.StartCPUProfile(f) pprof.StartCPUProfile(f)
defer pprof.StopCPUProfile()
OnInterrupt(func() { OnInterrupt(func() {
pprof.StopCPUProfile() pprof.StopCPUProfile()
}) })

25
weed/util/signal_handling.go

@ -5,13 +5,16 @@ package util
import ( import (
"os" "os"
"os/signal" "os/signal"
"sync"
"syscall" "syscall"
) )
func OnInterrupt(fn func()) {
// deal with control+c,etc
signalChan := make(chan os.Signal, 1)
// controlling terminal close, daemon not exit
var signalChan chan os.Signal
var hooks = make([]func(), 0)
var hookLock sync.Mutex
func init() {
signalChan = make(chan os.Signal, 1)
signal.Ignore(syscall.SIGHUP) signal.Ignore(syscall.SIGHUP)
signal.Notify(signalChan, signal.Notify(signalChan,
os.Interrupt, os.Interrupt,
@ -24,8 +27,20 @@ func OnInterrupt(fn func()) {
) )
go func() { go func() {
for _ = range signalChan { for _ = range signalChan {
fn()
for _, hook := range hooks {
hook()
}
os.Exit(0) os.Exit(0)
} }
}() }()
} }
func OnInterrupt(fn func()) {
// prevent reentry
hookLock.Lock()
defer hookLock.Unlock()
// deal with control+c,etc
// controlling terminal close, daemon not exit
hooks = append(hooks, fn)
}
Loading…
Cancel
Save