You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
94 lines
2.0 KiB
94 lines
2.0 KiB
5 years ago
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a MIT-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
package graceful
|
||
|
|
||
|
import (
|
||
|
"os"
|
||
|
"os/signal"
|
||
|
"syscall"
|
||
|
"time"
|
||
|
|
||
|
"code.gitea.io/gitea/modules/log"
|
||
|
"code.gitea.io/gitea/modules/setting"
|
||
|
)
|
||
|
|
||
|
var hookableSignals []os.Signal
|
||
|
|
||
|
func init() {
|
||
|
hookableSignals = []os.Signal{
|
||
|
syscall.SIGHUP,
|
||
|
syscall.SIGUSR1,
|
||
|
syscall.SIGUSR2,
|
||
|
syscall.SIGINT,
|
||
|
syscall.SIGTERM,
|
||
|
syscall.SIGTSTP,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// handleSignals listens for os Signals and calls any hooked in function that the
|
||
|
// user had registered with the signal.
|
||
|
func (srv *Server) handleSignals() {
|
||
|
var sig os.Signal
|
||
|
|
||
|
signal.Notify(
|
||
|
srv.sigChan,
|
||
|
hookableSignals...,
|
||
|
)
|
||
|
|
||
|
pid := syscall.Getpid()
|
||
|
for {
|
||
|
sig = <-srv.sigChan
|
||
|
srv.preSignalHooks(sig)
|
||
|
switch sig {
|
||
|
case syscall.SIGHUP:
|
||
|
if setting.GracefulRestartable {
|
||
|
log.Info("PID: %d. Received SIGHUP. Forking...", pid)
|
||
|
err := srv.fork()
|
||
|
if err != nil {
|
||
|
log.Error("Error whilst forking from PID: %d : %v", pid, err)
|
||
|
}
|
||
|
} else {
|
||
|
log.Info("PID: %d. Received SIGHUP. Not set restartable. Shutting down...", pid)
|
||
|
|
||
|
srv.shutdown()
|
||
|
}
|
||
|
case syscall.SIGUSR1:
|
||
|
log.Info("PID %d. Received SIGUSR1.", pid)
|
||
|
case syscall.SIGUSR2:
|
||
|
log.Warn("PID %d. Received SIGUSR2. Hammering...", pid)
|
||
|
srv.hammerTime(0 * time.Second)
|
||
|
case syscall.SIGINT:
|
||
|
log.Warn("PID %d. Received SIGINT. Shutting down...", pid)
|
||
|
srv.shutdown()
|
||
|
case syscall.SIGTERM:
|
||
|
log.Warn("PID %d. Received SIGTERM. Shutting down...", pid)
|
||
|
srv.shutdown()
|
||
|
case syscall.SIGTSTP:
|
||
|
log.Info("PID %d. Received SIGTSTP.")
|
||
|
default:
|
||
|
log.Info("PID %d. Received %v.", sig)
|
||
|
}
|
||
|
srv.postSignalHooks(sig)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (srv *Server) preSignalHooks(sig os.Signal) {
|
||
|
if _, notSet := srv.PreSignalHooks[sig]; !notSet {
|
||
|
return
|
||
|
}
|
||
|
for _, f := range srv.PreSignalHooks[sig] {
|
||
|
f()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (srv *Server) postSignalHooks(sig os.Signal) {
|
||
|
if _, notSet := srv.PostSignalHooks[sig]; !notSet {
|
||
|
return
|
||
|
}
|
||
|
for _, f := range srv.PostSignalHooks[sig] {
|
||
|
f()
|
||
|
}
|
||
|
}
|