aboutsummaryrefslogtreecommitdiff
path: root/weed/util/grace/signal_handling.go
diff options
context:
space:
mode:
authorbingoohuang <bingoo.huang@gmail.com>2021-04-26 17:19:35 +0800
committerbingoohuang <bingoo.huang@gmail.com>2021-04-26 17:19:35 +0800
commitd861cbd81b75b6684c971ac00e33685e6575b833 (patch)
tree301805fef4aa5d0096bfb1510536f7a009b661e7 /weed/util/grace/signal_handling.go
parent70da715d8d917527291b35fb069fac077d17b868 (diff)
parent4ee58922eff61a5a4ca29c0b4829b097a498549e (diff)
downloadseaweedfs-d861cbd81b75b6684c971ac00e33685e6575b833.tar.xz
seaweedfs-d861cbd81b75b6684c971ac00e33685e6575b833.zip
Merge branch 'master' of https://github.com/bingoohuang/seaweedfs
Diffstat (limited to 'weed/util/grace/signal_handling.go')
-rw-r--r--weed/util/grace/signal_handling.go46
1 files changed, 46 insertions, 0 deletions
diff --git a/weed/util/grace/signal_handling.go b/weed/util/grace/signal_handling.go
new file mode 100644
index 000000000..7cca46764
--- /dev/null
+++ b/weed/util/grace/signal_handling.go
@@ -0,0 +1,46 @@
+// +build !plan9
+
+package grace
+
+import (
+ "os"
+ "os/signal"
+ "sync"
+ "syscall"
+)
+
+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.Notify(signalChan,
+ os.Interrupt,
+ os.Kill,
+ syscall.SIGALRM,
+ // syscall.SIGHUP,
+ syscall.SIGINT,
+ syscall.SIGTERM,
+ // syscall.SIGQUIT,
+ )
+ go func() {
+ for _ = range signalChan {
+ for _, hook := range hooks {
+ hook()
+ }
+ 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)
+}