caddyhttp: Register post-shutdown callbacks (#5948)

This commit is contained in:
Matt Holt 2024-02-14 21:21:23 -07:00 committed by GitHub
parent 2c48dda109
commit 127788807f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 18 additions and 1 deletions

View file

@ -642,6 +642,15 @@ func (app *App) Stop() error {
finishedShutdown.Wait() finishedShutdown.Wait()
} }
// run stop callbacks now that the server shutdowns are complete
for name, s := range app.Servers {
for _, stopHook := range s.onStopFuncs {
if err := stopHook(ctx); err != nil {
app.logger.Error("server stop hook", zap.String("server", name), zap.Error(err))
}
}
}
return nil return nil
} }

View file

@ -253,6 +253,7 @@ type Server struct {
connStateFuncs []func(net.Conn, http.ConnState) connStateFuncs []func(net.Conn, http.ConnState)
connContextFuncs []func(ctx context.Context, c net.Conn) context.Context connContextFuncs []func(ctx context.Context, c net.Conn) context.Context
onShutdownFuncs []func() onShutdownFuncs []func()
onStopFuncs []func(context.Context) error // TODO: Experimental (Nov. 2023)
} }
// ServeHTTP is the entry point for all HTTP requests. // ServeHTTP is the entry point for all HTTP requests.
@ -630,11 +631,18 @@ func (s *Server) RegisterConnContext(f func(ctx context.Context, c net.Conn) con
s.connContextFuncs = append(s.connContextFuncs, f) s.connContextFuncs = append(s.connContextFuncs, f)
} }
// RegisterOnShutdown registers f to be invoked on server shutdown. // RegisterOnShutdown registers f to be invoked when the server begins to shut down.
func (s *Server) RegisterOnShutdown(f func()) { func (s *Server) RegisterOnShutdown(f func()) {
s.onShutdownFuncs = append(s.onShutdownFuncs, f) s.onShutdownFuncs = append(s.onShutdownFuncs, f)
} }
// RegisterOnStop registers f to be invoked after the server has shut down completely.
//
// EXPERIMENTAL: Subject to change or removal.
func (s *Server) RegisterOnStop(f func(context.Context) error) {
s.onStopFuncs = append(s.onStopFuncs, f)
}
// HTTPErrorConfig determines how to handle errors // HTTPErrorConfig determines how to handle errors
// from the HTTP handlers. // from the HTTP handlers.
type HTTPErrorConfig struct { type HTTPErrorConfig struct {