答案:在Golang中实现云原生健康检查需提供/health/ready和/health/live两个HTTP端点,分别用于就绪与存活探测,返回JSON格式状态信息;就绪检查依赖外部服务连接(如DB、Redis),存活检查仅判断进程自身健康;使用context超时控制避免阻塞,缓存探测结果提升性能;配合K8s配置initialDelaySeconds、periodSeconds等参数,确保探针合理触发,避免误重启。
在 Golang 中实现云原生应用的健康检查,核心是提供标准、可靠、可扩展的 HTTP 端点(如 /health),让 Kubernetes、Service Mesh 或负载均衡器能自动感知服务状态。关键不在于“写个接口”,而在于检查内容是否真实反映服务可用性,并与平台行为对齐。
Kubernetes 默认使用 HTTP GET 请求探测 livenessProbe 和 readinessProbe,要求返回 200 状态码表示通过。Golang 可用标准 net/http 快速暴露端点:
GET /health/ready(就绪)和 GET /health/live(存活),语义清晰且便于分别配置二者目的不同,实现必须分离:
真实场景中,健康检查需反馈下游依赖状态,但不能因此变慢或失败。推荐方式:
context.WithTimeout 包裹 DB Ping、Redis Echo、HTTP Head 请求Go 服务写得再好,K8s 配置不合理也会导致反复重启或流量涌入失败实例:
基本上就这些。健康检查不是锦上添花的功能,而是云原生服务的呼吸节奏——写得松散,K8s 就替你做决定;写得精准,才能稳住流量、快速自愈、便于排障。