Reinicialização ou Interrupção Graciosa
Queres reiniciar ou parar graciosamente o teu servidor de web? Existem algumas maneiras disto poder ser feito.
Nós podemos usar o fvbock/endless para substituir o ListenAndServe
padrão. Consulte a questão #296 por mais detalhes:
router := gin.Default()router.GET("/", handler)endless.ListenAndServe(":4242", router)
Uma alternativa ao endless
:
manners
: Um servidor de HTTP de Go delicado que desliga graciosamente.graceful
: é uma pacote de Go que ativa a paragem graciosa dum servidor dehttp.Handler
.grace
: reinicialização graciosa & implementação de produção de tempo de inatividade zero para servidores de Go.
Se usas a Go 1.8, podes não precisar de usar esta biblioteca! Considere usar o método Shutdown() embutido da http.Server
para paragens graciosas. Consulte o exemplo graceful-shutdown completo com a Gin:
//go:build go1.8// +build go1.8
package main
import ( "context" "log" "net/http" "os" "os/signal" "syscall" "time"
"github.com/gin-gonic/gin")
func main() { router := gin.Default() router.GET("/", func(c *gin.Context) { time.Sleep(5 * time.Second) c.String(http.StatusOK, "Welcome Gin Server") })
srv := &http.Server{ Addr: ":8080", Handler: router.Handler(), }
go func() { // service connections if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed { log.Fatalf("listen: %s\n", err) } }()
// Wait for interrupt signal to gracefully shutdown the server with // a timeout of 5 seconds. quit := make(chan os.Signal, 1) // kill (no params) by default sends syscall.SIGTERM // kill -2 is syscall.SIGINT // kill -9 is syscall.SIGKILL but can't be caught, so don't need add it signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM) <-quit log.Println("Shutdown Server ...")
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second) defer cancel() if err := srv.Shutdown(ctx); err != nil { log.Println("Server Shutdown:", err) } log.Println("Server exiting")}