<分区>
在构建自定义服务器应用程序时,最好有一个关闭机制,以确保我们所有正在运行的进程在服务器关闭之前停止,这也有助于更好的内存管理。
我们如何利用 Golang 及其功能构建这样的机制?
Golang 中已经有一个 shutdown
函数,我的想法是让开发人员跳出框框思考并创建多个
做同样的方法。它将有助于使我们的 golang 社区变得更好、更强大。下面分享我的一个回答,希望大家多提建议和解答。😊
<分区>
在构建自定义服务器应用程序时,最好有一个关闭机制,以确保我们所有正在运行的进程在服务器关闭之前停止,这也有助于更好的内存管理。
我们如何利用 Golang 及其功能构建这样的机制?
Golang 中已经有一个 shutdown
函数,我的想法是让开发人员跳出框框思考并创建多个
做同样的方法。它将有助于使我们的 golang 社区变得更好、更强大。下面分享我的一个回答,希望大家多提建议和解答。😊
最佳答案
package main
import (
"context"
"log"
"net/http"
"os"
"os/signal"
)
func main() {
var srv http.Server
idleConnsClosed := make(chan struct{})
go func() {
sigint := make(chan os.Signal, 1)
signal.Notify(sigint, os.Interrupt)
<-sigint
// We received an interrupt signal, shut down.
if err := srv.Shutdown(context.Background()); err != nil {
// Error from closing listeners, or context timeout:
log.Printf("HTTP server Shutdown: %v", err)
}
close(idleConnsClosed)
}()
if err := srv.ListenAndServe(); err != http.ErrServerClosed {
// Error starting or closing listener:
log.Printf("HTTP server ListenAndServe: %v", err)
}
<-idleConnsClosed
}
关于go - 如何优雅地关闭 golang 服务器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54978683/