golang net/http包在k8s使用中碰到http: superfluous response.WriteHeader call from xxx的问题

      在项目中,需要使用golang写http服务器并部署在k8s中,在server deployment.yaml中存在livenessProbe(存活探针)以及readinessProbe(就绪探针),这两个我都是写了向服务器发送一个http请求,如果服务器收到并回复,则表示成功,但是在使用过程中,日志一直输出,这些会干扰日志的查看。

经过查询与测试,最后修复,做此纪录,代码如下。

func healthcheck(w http.ResponseWriter, r *http.Request) {
    //fmt.Fprintf(w, "i m live") 原来就是因为多了这行,然后一直输出,屏蔽了即可
	w.WriteHeader(200)
}

func main() {
    router := http.NewServeMux()
    router.HandleFunc("/healthcheck", healthcheck)
	port := fmt.Sprint(":", *config.Conf.HttpPort)
	srv := &http.Server{
		Addr:    port,
		Handler: router,
	}

	logger.Info("[HTTP] http server listen", port)
	if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
		logger.Error("[HTTP] server listen on", port, ", err:", err)
		os.Exit(1)
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值