Small Go module for running HTTP servers with graceful shutdown and sensible defaults.
go get github.com/containeroo/httpgraceRun(ctx, listenAddr, router, logger, opts...)builds anhttp.Serverand runs it.RunServer(ctx, server, logger)runs an already configured*http.Server.- Both return startup and shutdown errors to the caller.
loggeris optional; whennil, lifecycle logging is disabled.
ReadHeaderTimeout:10sWriteTimeout:15sIdleTimeout:60sShutdownTimeout:10s
package main
import (
"context"
"log/slog"
"net/http"
"os"
"os/signal"
"syscall"
"github.com/containeroo/httpgrace/server"
)
func main() {
logger := slog.New(slog.NewTextHandler(os.Stdout, nil))
mux := http.NewServeMux()
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
_, _ = w.Write([]byte("ok"))
})
ctx, stop := signal.NotifyContext(context.Background(), os.Interrupt, syscall.SIGTERM)
defer stop()
if err := server.Run(ctx, ":8080", mux, logger); err != nil {
logger.Error("server stopped with error", "err", err)
}
}package main
import (
"context"
"log/slog"
"net/http"
"os"
"os/signal"
"syscall"
"time"
"github.com/containeroo/httpgrace/server"
)
func main() {
logger := slog.New(slog.NewTextHandler(os.Stdout, nil))
mux := http.NewServeMux()
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
_, _ = w.Write([]byte("ok"))
})
srv := &http.Server{
Addr: ":8080",
Handler: mux,
ReadHeaderTimeout: 5 * time.Second,
WriteTimeout: 10 * time.Second,
IdleTimeout: 30 * time.Second,
}
ctx, stop := signal.NotifyContext(context.Background(), os.Interrupt, syscall.SIGTERM)
defer stop()
if err := server.RunServer(ctx, srv, logger); err != nil {
logger.Error("server stopped with error", "err", err)
}
}This module was inspired by the Grafana blog post:
https://grafana.com/blog/2024/02/09/how-i-write-http-services-in-go-after-13-years/
This project is licensed under the Apache 2.0 License. See the LICENSE file for details.