cmd/koushin: reload on SIGUSR1

References: https://todo.sr.ht/~sircmpwn/koushin/43
This commit is contained in:
Simon Ser 2020-01-08 11:02:13 +01:00
parent 97b314b6e7
commit 3d8569d185
No known key found for this signature in database
GPG key ID: 0FDE7BE0E88F5E48

View file

@ -3,6 +3,9 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"os"
"os/signal"
"syscall"
"git.sr.ht/~emersion/koushin" "git.sr.ht/~emersion/koushin"
"github.com/labstack/echo/v4" "github.com/labstack/echo/v4"
@ -35,10 +38,22 @@ func main() {
if l, ok := e.Logger.(*log.Logger); ok { if l, ok := e.Logger.(*log.Logger); ok {
l.SetHeader("${time_rfc3339} ${level}") l.SetHeader("${time_rfc3339} ${level}")
} }
_, err := koushin.New(e, &options) s, err := koushin.New(e, &options)
if err != nil { if err != nil {
e.Logger.Fatal(err) e.Logger.Fatal(err)
} }
e.Use(middleware.Recover()) e.Use(middleware.Recover())
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGUSR1)
go func() {
for range sigs {
e.Logger.Printf("Reloading server")
if err := s.Reload(); err != nil {
e.Logger.Errorf("Failed to reload server: %v", err)
}
}
}()
e.Logger.Fatal(e.Start(":1323")) e.Logger.Fatal(e.Start(":1323"))
} }