Comme mentionné en yo.ian.g
's réponse. Aller 1.8 a inclus cette fonctionnalité dans la lib standard.
Exemple Minimal pour pour Go 1.8+
:
server := &http.Server{Addr: ":8080", Handler: handler}
go func() {
if err := server.ListenAndServe(); err != nil {
// handle err
}
}
// Setting up signal capturing
stop := make(chan os.Signal, 1)
signal.Notify(stop, os.Interrupt)
// Waiting for SIGINT (pkill -2)
<-stop
ctx, _ := context.WithTimeout(context.Background(), 5*time.Second)
if err := server.Shutdown(ctx); err != nil {
// handle err
}
Réponse Originale À Cette Question - Pré Aller 1.8 :
Bâtiment sur Uvelichitel de réponse.
Vous pouvez créer votre propre version d' ListenAndServe
qui retourne un io.Closer
et ne se 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 terminerai avec l'erreur
accept tcp [::]:8080: use of closed network connection