2 回答
TA贡献1806条经验 获得超5个赞
Kubernetes 发出一个SIGTERM信号。所以优雅的关机可能看起来像这样:
package main
import (
"context"
"log"
"net/http"
"os"
"os/signal"
"syscall"
)
func main() {
var srv http.Server
idleConnsClosed := make(chan struct{})
go func() {
sigint := make(chan os.Signal, 1)
// interrupt signal sent from terminal
signal.Notify(sigint, os.Interrupt)
// sigterm signal sent from kubernetes
signal.Notify(sigint, syscall.SIGTERM)
<-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
}
您还应该将 Liveness 和 Readiness 探测器添加到您的 Pod 中:
livenessProbe:
httpGet:
path: /health
port: 80
readinessProbe:
httpGet:
path: /health
port: 80
TA贡献1830条经验 获得超3个赞
当 Kubernetes 发送SIGTERM
信号流量仍然可以路由到 pod 时,因为从端点集和SIGTERM
信号中删除 pod 是异步的——如果 pod 在SIGTERM
端点之后可能没有时间更新。 SIGTERM
只是礼貌地要求开始收尾,但不要立即停止接受新的请求。
您可以在<-sigint
部署之后或添加到部署中后将睡眠添加到您的代码中
lifecycle: preStop: exec: command: ["sh", "-c", "sleep 10"]
- 2 回答
- 0 关注
- 137 浏览
添加回答
举报