Comme mentionné dans yo.ian.g
la réponse de. Go 1.8 a inclus cette fonctionnalité dans la bibliothèque standard.
Exemple minimal pour pour Go 1.8+
:
server := &http.Server{Addr: ":8080", Handler: handler}
go func() {
if err := server.ListenAndServe(); err != nil {
}
}()
stop := make(chan os.Signal, 1)
signal.Notify(stop, os.Interrupt)
<-stop
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
if err := server.Shutdown(ctx); err != nil {
}
Réponse originale - Pre Go 1.8:
S'appuyant sur la réponse d'Uvelichitel .
Vous pouvez créer votre propre version ListenAndServe
dont renvoie un io.Closer
et ne bloque pas.
func ListenAndServeWithClose(addr string, handler http.Handler) (io.Closer,error) {
var (
listener net.Listener
srvCloser io.Closer
err error
)
srv := &http.Server{Addr: addr, Handler: handler}
if addr == "" {
addr = ":http"
}
listener, err = net.Listen("tcp", addr)
if err != nil {
return nil, err
}
go func() {
err := srv.Serve(tcpKeepAliveListener{listener.(*net.TCPListener)})
if err != nil {
log.Println("HTTP Server Error - ", err)
}
}()
srvCloser = listener
return srvCloser, nil
}
Code complet disponible ici .
Le serveur HTTP se fermera avec l'erreur
accept tcp [::]:8080: use of closed network connection