mirror of
https://github.com/nais/wonderwall.git
synced 2026-02-14 17:49:54 +00:00
63 lines
1.7 KiB
Go
63 lines
1.7 KiB
Go
package server
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"net/http"
|
|
"os"
|
|
"os/signal"
|
|
"syscall"
|
|
"time"
|
|
|
|
"github.com/go-chi/chi/v5"
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"github.com/nais/wonderwall/pkg/config"
|
|
)
|
|
|
|
func Start(cfg *config.Config, r chi.Router) error {
|
|
server := http.Server{
|
|
Addr: cfg.BindAddress,
|
|
Handler: r,
|
|
}
|
|
|
|
serverCtx, serverStopCtx := context.WithCancel(context.Background())
|
|
|
|
sig := make(chan os.Signal, 1)
|
|
signal.Notify(sig, syscall.SIGHUP, syscall.SIGINT, syscall.SIGTERM, syscall.SIGQUIT)
|
|
go func() {
|
|
s := <-sig
|
|
log.Infof("server: received %q; waiting for %s before starting graceful shutdown...", s, cfg.ShutdownWaitBeforePeriod)
|
|
time.Sleep(cfg.ShutdownWaitBeforePeriod)
|
|
|
|
// the total terminationGracePeriodSeconds in Kubernetes starts immediately when SIGTERM is sent, so we need to subtract the wait-before period to exit before SIGKILL
|
|
shutdownTimeout := cfg.ShutdownGracefulPeriod - cfg.ShutdownWaitBeforePeriod
|
|
shutdownCtx, shutdownStopCtx := context.WithTimeout(serverCtx, shutdownTimeout)
|
|
|
|
go func() {
|
|
<-shutdownCtx.Done()
|
|
if errors.Is(shutdownCtx.Err(), context.DeadlineExceeded) {
|
|
log.Fatalf("server: graceful shutdown timed out after %s; forcing exit.", shutdownTimeout)
|
|
}
|
|
}()
|
|
|
|
log.Infof("server: starting graceful shutdown (will timeout after %s)...", shutdownTimeout)
|
|
err := server.Shutdown(shutdownCtx)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
shutdownStopCtx()
|
|
serverStopCtx()
|
|
}()
|
|
|
|
log.Infof("server: listening on %s", cfg.BindAddress)
|
|
err := server.ListenAndServe()
|
|
if err != nil && !errors.Is(err, http.ErrServerClosed) {
|
|
return err
|
|
}
|
|
|
|
<-serverCtx.Done()
|
|
log.Infof("server: shutdown completed")
|
|
return nil
|
|
}
|