kubelet: Surface description for predicate failed Events #125498
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What type of PR is this?
/kind feature
/sig node
What this PR does / why we need it:
Problem:
When a Pod fails to start due to kubelet-side admission checks, kubelet reports
v1/Eventfor the Pod using the following event payload format:This is not super helpful, to especially to beginners who do not know that kubelet does admission checks after a pod that's scheduled and ran on the host before. It's also unclear the what the names of predicates refer to.
Solution:
Expose human-readable predicate description in the failure so that kubelet submits an
Eventwith this description, such as:Which issue(s) this PR fixes:
N/A - have not opened an issue since it's a small change that seems rather inconsequential.
Special notes for your reviewer:
Tested with a new kubelet build from HEAD in
kind, and triggering the predicate failures listed above.Does this PR introduce a user-facing change?
Additional documentation e.g., KEPs (Kubernetes Enhancement Proposals), usage docs, etc.: