SRE Troubleshooting Checklist
Pods
Pods that are unable to start do not show any log output, the issue is related to k8s. Look for a pod with status Pending. Most of the time this is related to resources and container component issues.
-
Describe the pod, look closely at listed events
-
Is the image pullable? Is there a pull secret configured?
-
Can volumes, configmaps and secrets be mounted?
-
Check resource requests: is the requested resource available?
-
Are commands and arguments correct? (make sure to use /bin/sh -c as command to use ENV)
-
Does the cluster have enough resources available?
Pod status
Pods that are running but restart for whatever reason indicate that a container itself is having issues. Look for pod status Crashloop, OOMkilled
or incomplete ready status (2/3)
-
Check if DNS resolving works
-
Are the required services available to the pod?
-
Check restart count and inspect logs and previous logs
-
Check if istio injection is required and working
-
Is a lifecycle spec configured?
-
Does the container depend on sidecar containers?
-
Check for available resources requests
-
Check readiness and liveness probes
-
Does the pod have enough CPU resources to do it's job?
-
Inspect the restart counter for the pod, a high value (32+) indicates an unstable pod
-
Check pod's service account permissions
-
Attach shell and inspect container status
-
Rootless containers need special care combined with volumes
-
Check securitycontext and pod security policy
-
Check volume permissions
Advanced
-
Check affinity and node selector rules
-
Is the image tag valid and compatible with the host CPU? (exec format error)
-
Check namespace quotas for pod, cm or secret limits etc.
-
Check service account and permissions
-
Is the pod a job, deployment, daemonset or statefulset?
-
Is there a limitrange configured in the namespace?
-
Is the template spec in the pod matching the running container?
Services
Pods are working but a user can't connect to the service. Most HTTP-based services use an Ingress object, non HTTP services require a service port to be defined.
Network policies or Istio policies can deny pods from communicating, note that DNS resolving is required for normal operation.
-
Check if network policies are too strict by removing suspect one(s) (if so report an issue to have it/them refactored, if not put back)
-
Use
kubectl port-forward
to debug pod service on lowest level -
Check if kube-dns / coredns pods are working in kube-system namespace
-
Check invalid DNS names, too long (64+) or invalid characters
-
Attach a shell and perform basic nslookup or ping commands (ping doesn't work between internal services in k8s)
-
Confirm that services do not mix http and https in frontend and backend
-
Service names matter, prefix accordingly with http- or https- for istio to recognize
-
Validate ingress, istio gateway, virtual service and services
Advanced
-
Check for network policies
-
Validate Istio pods are working
-
Check if Istio injection is configured and working
-
Validate Istio-operator working
-
Run
istioctl analyze
Istio
Istio sidecars manipulate the container's network to reroute traffic. A namespace can have an Istio sidecar policy indicated by a label, the same is valid for a deployment or pod. Make sure you see Istio sidecars running when applicable (indicated by the 3/3 Ready status).
-
Check if istio-operator is working
-
Check logs for istiod pods
-
Are services correctly named? (istio treats http- prefix and https- prefix differently)
-
Check the logs of the Istio sidecar proxy
-
Check if mtls is enabled and working
Advanced
-
Is the correct service account configured?
-
Is Istio mTLS enabled and configured correctly?
-
Turn on logging for a context of an istio sidecar:
ksh exec -it $container_id -c istio-proxy -- sh -c 'curl -k -X POST localhost:15000/logging?jwt=debug'
ExternalDNS
The ExternalDNS service is registering DNS names to makes sure that the service names are publicly available.
-
Make sure
external-dns
logs indicate All records are already up to date -
Are the credentials configured correctly?
Cert-manager
Check cert-manager working:
-
Run
kubectl describe orders.acme.cert-manager.io -A
-
Run
kubectl describe challenges.acme.cert-manager.io -A
-
Run
kubectl describe certificates.cert-manager.io -A