Gateway health checks
Enable a health check plugin on your gateway proxy to respond with common HTTP codes.
Gloo Gateway includes an HTTP health checking plug-in that you can enable for a gateway proxy listener. This plug-in responds to health check requests directly with either a 200 OK or 503 Service Unavailable message, depending on the current draining state of Envoy.
The steps in this section use the Envoy-based kgateway data plane. The steps do not work with the agentgateway data plane.
Before you begin
Follow the Get started guide to install Gloo Gateway.
Follow the Sample app guide to create a gateway proxy with an HTTP listener and deploy the httpbin sample app.
Get the external address of the gateway and save it in an environment variable.
Configure a health check on a gateway
Create an HTTPListenerPolicy resource to configure a health check path for the HTTP or HTTPS listener on the gateway. You can define any path, such as
/check/healthz.kubectl apply -f- <<EOF apiVersion: gateway.kgateway.dev/v1alpha1 kind: HTTPListenerPolicy metadata: name: healthcheck namespace: gloo-system spec: targetRefs: - group: gateway.networking.k8s.io kind: Gateway name: http healthCheck: path: <path> EOFTo test the health check, drain the Envoy connections by sending an
HTTP POSTrequest to the/healthcheck/failendpoint of the Envoy admin port.- Port-forward the
httpdeployment on port 19000.kubectl port-forward deploy/http -n gloo-system 19000 & - Send an
HTTP POSTrequest to the/healthcheck/failendpoint. This causes Envoy connections to begin draining.curl -X POST 127.0.0.1:19000/healthcheck/fail
- Port-forward the
Send a request to the health check path. Because Envoy is in a draining state, the
503 Service Unavailablemessage is returned.Example output:
HTTP/1.1 503 Service Unavailable x-envoy-upstream-healthchecked-cluster: http.gloo-system x-envoy-immediate-health-check-fail: true date: Wed, 16 Jul 2025 16:35:12 GMT server: envoy connection: close content-length: 0After you finish testing, resume Envoy connections by sending an
HTTP POSTrequest to the/healthcheck/okendpoint of the Envoy admin port.curl -X POST 127.0.0.1:19000/healthcheck/okSend another request to the health check path. Because Envoy is operating normally, the
200 OKmessage is returned.Example output:
HTTP/1.1 200 OK x-envoy-upstream-healthchecked-cluster: http.gloo-system date: Wed, 16 Jul 2025 16:37:13 GMT server: envoy content-length: 0Stop port-forwarding the
httpdeployment.lsof -ti:19000 | xargs kill -9
Cleanup
You can remove the resources that you created in this guide.
kubectl delete HTTPListenerPolicy healthcheck -n gloo-system