1
0
mirror of https://github.com/containous/traefik.git synced 2025-01-22 22:03:51 +03:00
traefik/pkg/server/server_signals.go

34 lines
603 B
Go

//go:build !windows
// +build !windows
package server
import (
"context"
"os/signal"
"syscall"
"github.com/rs/zerolog/log"
)
func (s *Server) configureSignals() {
signal.Notify(s.signals, syscall.SIGUSR1)
}
func (s *Server) listenSignals(ctx context.Context) {
for {
select {
case <-ctx.Done():
return
case sig := <-s.signals:
if sig == syscall.SIGUSR1 {
log.Info().Msgf("Closing and re-opening log files for rotation: %+v", sig)
if err := s.observabilityMgr.RotateAccessLogs(); err != nil {
log.Error().Err(err).Msg("Error rotating access log")
}
}
}
}
}