mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-09-18 19:19:24 +08:00
master fix interruption through ctrl+c (#3834)
This commit is contained in:

committed by
GitHub

parent
a05725aea6
commit
401315f337
@@ -4,8 +4,11 @@
|
||||
package grace
|
||||
|
||||
import (
|
||||
"github.com/seaweedfs/seaweedfs/weed/glog"
|
||||
"os"
|
||||
"os/signal"
|
||||
"reflect"
|
||||
"runtime"
|
||||
"sync"
|
||||
"syscall"
|
||||
)
|
||||
@@ -16,6 +19,10 @@ var interruptHookLock sync.RWMutex
|
||||
var reloadHooks = make([]func(), 0)
|
||||
var reloadHookLock sync.RWMutex
|
||||
|
||||
func GetFunctionName(i interface{}) string {
|
||||
return runtime.FuncForPC(reflect.ValueOf(i).Pointer()).Name()
|
||||
}
|
||||
|
||||
func init() {
|
||||
signalChan = make(chan os.Signal, 1)
|
||||
signal.Notify(signalChan,
|
||||
@@ -38,6 +45,7 @@ func init() {
|
||||
} else {
|
||||
interruptHookLock.RLock()
|
||||
for _, hook := range interruptHooks {
|
||||
glog.V(4).Infof("exec interrupt hook func name:%s", GetFunctionName(hook))
|
||||
hook()
|
||||
}
|
||||
interruptHookLock.RUnlock()
|
||||
|
Reference in New Issue
Block a user