Skip to content

Instantly share code, notes, and snippets.

@gigenthomas
Created April 4, 2025 03:12
Show Gist options
  • Select an option

  • Save gigenthomas/74c80c9d2e5f765b59188b1e73a99ee1 to your computer and use it in GitHub Desktop.

Select an option

Save gigenthomas/74c80c9d2e5f765b59188b1e73a99ee1 to your computer and use it in GitHub Desktop.
package main
import (
"context"
"fmt"
"log"
"net/http"
"os"
"os/signal"
"syscall"
"time"
"github.com/go-chi/chi/v5"
"github.com/go-chi/chi/v5/middleware"
)
func main() {
r := chi.NewRouter()
// Use chi middleware
r.Use(middleware.Logger)
r.Use(middleware.Recoverer)
r.Use(middleware.Timeout(60 * time.Second))
// Define routes
r.Get("/", func(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Hello, world!"))
})
srv := &http.Server{
Addr: ":8080",
Handler: r,
}
// Channel to listen for termination signals
quit := make(chan os.Signal, 1)
signal.Notify(quit, os.Interrupt, syscall.SIGTERM)
go func() {
log.Println("Starting server on :8080")
if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
log.Fatalf("ListenAndServe error: %v", err)
}
}()
// Wait for termination signal
<-quit
log.Println("Shutting down server...")
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
if err := srv.Shutdown(ctx); err != nil {
log.Fatalf("Server forced to shutdown: %v", err)
}
log.Println("Server exited gracefully")
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment