mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-10 18:24:44 +00:00
Implement signal handling
With this change, the behavior is as follows: - SIGTERM / SIGINT: Exit cleanly (exit code 0) - SIGHUP: Restart This is the case both when hitting the monitor process or the inner process, or if running with NORESTART (but then we won't restart, obviously, just exit with code exitRestarting). It enables "pkill -HUP syncthing" to do the right thing to restart all Syncthings on package upgrade, for example.
This commit is contained in:
parent
29bff06cd6
commit
7b686c1103
@ -19,6 +19,7 @@ import (
|
|||||||
_ "net/http/pprof"
|
_ "net/http/pprof"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
"os/signal"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"regexp"
|
"regexp"
|
||||||
"runtime"
|
"runtime"
|
||||||
@ -26,6 +27,7 @@ import (
|
|||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"syscall"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/syncthing/syncthing/lib/config"
|
"github.com/syncthing/syncthing/lib/config"
|
||||||
@ -462,6 +464,8 @@ func upgradeViaRest() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func syncthingMain() {
|
func syncthingMain() {
|
||||||
|
setupSignalHandling()
|
||||||
|
|
||||||
// Create a main service manager. We'll add things to this as we go along.
|
// Create a main service manager. We'll add things to this as we go along.
|
||||||
// We want any logging it does to go through our log system.
|
// We want any logging it does to go through our log system.
|
||||||
mainSvc := suture.New("main", suture.Spec{
|
mainSvc := suture.New("main", suture.Spec{
|
||||||
@ -839,6 +843,28 @@ func syncthingMain() {
|
|||||||
os.Exit(code)
|
os.Exit(code)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func setupSignalHandling() {
|
||||||
|
// Exit cleanly with "restarting" code on SIGHUP.
|
||||||
|
|
||||||
|
restartSign := make(chan os.Signal, 1)
|
||||||
|
sigHup := syscall.Signal(1)
|
||||||
|
signal.Notify(restartSign, sigHup)
|
||||||
|
go func() {
|
||||||
|
<-restartSign
|
||||||
|
stop <- exitRestarting
|
||||||
|
}()
|
||||||
|
|
||||||
|
// Exit with "success" code (no restart) on INT/TERM
|
||||||
|
|
||||||
|
stopSign := make(chan os.Signal, 1)
|
||||||
|
sigTerm := syscall.Signal(15)
|
||||||
|
signal.Notify(stopSign, os.Interrupt, sigTerm)
|
||||||
|
go func() {
|
||||||
|
<-stopSign
|
||||||
|
stop <- exitSuccess
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
|
||||||
// printHashRate prints the hashing performance in MB/s, formatting it with
|
// printHashRate prints the hashing performance in MB/s, formatting it with
|
||||||
// appropriate precision for the value, i.e. 182 MB/s, 18 MB/s, 1.8 MB/s, 0.18
|
// appropriate precision for the value, i.e. 182 MB/s, 18 MB/s, 1.8 MB/s, 0.18
|
||||||
// MB/s.
|
// MB/s.
|
||||||
|
@ -62,9 +62,12 @@ func monitorMain() {
|
|||||||
args := os.Args
|
args := os.Args
|
||||||
var restarts [countRestarts]time.Time
|
var restarts [countRestarts]time.Time
|
||||||
|
|
||||||
sign := make(chan os.Signal, 1)
|
stopSign := make(chan os.Signal, 1)
|
||||||
sigTerm := syscall.Signal(0xf)
|
sigTerm := syscall.Signal(15)
|
||||||
signal.Notify(sign, os.Interrupt, sigTerm, os.Kill)
|
signal.Notify(stopSign, os.Interrupt, sigTerm)
|
||||||
|
restartSign := make(chan os.Signal, 1)
|
||||||
|
sigHup := syscall.Signal(1)
|
||||||
|
signal.Notify(restartSign, sigHup)
|
||||||
|
|
||||||
for {
|
for {
|
||||||
if t := time.Since(restarts[0]); t < loopThreshold {
|
if t := time.Since(restarts[0]); t < loopThreshold {
|
||||||
@ -124,12 +127,17 @@ func monitorMain() {
|
|||||||
}()
|
}()
|
||||||
|
|
||||||
select {
|
select {
|
||||||
case s := <-sign:
|
case s := <-stopSign:
|
||||||
l.Infof("Signal %d received; exiting", s)
|
l.Infof("Signal %d received; exiting", s)
|
||||||
cmd.Process.Kill()
|
cmd.Process.Kill()
|
||||||
<-exit
|
<-exit
|
||||||
return
|
return
|
||||||
|
|
||||||
|
case s := <-restartSign:
|
||||||
|
l.Infof("Signal %d received; restarting", s)
|
||||||
|
cmd.Process.Signal(sigHup)
|
||||||
|
err = <-exit
|
||||||
|
|
||||||
case err = <-exit:
|
case err = <-exit:
|
||||||
if err == nil {
|
if err == nil {
|
||||||
// Successful exit indicates an intentional shutdown
|
// Successful exit indicates an intentional shutdown
|
||||||
|
Loading…
Reference in New Issue
Block a user