grpc health probes with kubernetes 1.24+
gRPC health probes are natively supported in beta since Kubernetes 1.24+. Before that we needed to add the grpc_health_probe
binary in each Dockerfile
.
Since the recent v0.4.1 version, the Online Boutique sample provides an option to have its applications supporting this feature. This allows to leverage the native Kubernetes feature, decrease the size of the container images by 4MB (virtual) and 11MB (on disk) as well as reduce the maintenance and surface of attack that this grpc_health_probe
binary was adding.
What are the differences with before?
In your Dockerfile
, you don’t need anymore to add the grpc_health_probe
binary (like we needed to previously):
In the Kubernetes manifests for your Deployments
, here is the associated updates for both the readinessProbe
and the livenessProbe
:
How to deploy the Online Boutique sample with this new feature?
Create a GKE cluster in version 1.24+:
Note: as of now, the default version of GKE in rapid channel is 1.24.
From there, let’s deploy the Online Boutique sample with the gRPC health probes experimental variation.
Get the remote Kustomize components:
Update the local Kustomize components:
Configure the Kustomize overlay:
Optionally, you can render the Kubernetes manifests:
In the Kubernetes manifests for the Deployments
, here is the associated update for the container image
:
Deploy this Kustomize overlay:
If you wait a little bit, when all the Pods
are running, you should have your Online Boutique website working successfully.
That’s how easy we were able to leverage the new native gRPC health probes with Kubernetes 1.24+ with the Online Boutique sample.
The Online Boutique sample apps are not yet supporting by default this native gRPC health probes, because Kubernetes 1.24+ is not widely nor commonly used yet. That’s why we need to use the optional associated Kustomize overlay.
Hope you enjoyed that one, happy sailing, cheers!