-
Notifications
You must be signed in to change notification settings - Fork 999
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs(concepts): Clarify podAffinity/podAntiAffinity note #948
docs(concepts): Clarify podAffinity/podAntiAffinity note #948
Conversation
✔️ Deploy Preview for karpenter-docs-prod ready! 🔨 Explore the source changes: a7cc75c 🔍 Inspect the deploy log: https://app.netlify.com/sites/karpenter-docs-prod/deploys/61b119ad5547db000852a67c 😎 Browse the preview: https://deploy-preview-948--karpenter-docs-prod.netlify.app |
This looks like a bad link: kubernetes/enhancements#249. Can you update? |
Oops I meant kubernetes/enhancements#2249 |
We didn't initially implement affinity due to:
I'm open minded to implementing pod antiaffinity (or at least a subset of the spec). However, pod affinity seems to be a bit of a nonstarter. When provisioning capacity, it's impossible to know whether or not all the pods that need to coschedule have been created yet. It's extremely easy to get wedged this way. This is more viable in static clusters, but still relatively challenging. I think your current docs change is a good recommendation, and we can continue the discussion in #942. tl;dr, given the number of charts that use antiaffinity, I think we may be causing undue pain by not supporting it. It's probably worth the investment, at least insofar as antiaffinity is translatable to topology. |
Thank you @ellistarn for the reply, I have updated the KEP link to point to the section describing the problems, please do not hesitate to suggest a better reference if you have one. |
Co-authored-by: Maxime Brunet <max@brnt.mx>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks!
I have finally found the literal recommendation
|
1. Issue, if available:
Related to #942
2. Description of changes:
Hello 👋
This notes has been confusing me since I read it. At first, I thought
podAntiAffinity
would cause scalability issues for the deployments using them, but reading further aroundtopologySpreadConstraints
(especially its KEP), it seems to be an issue for scalability of the Kubernetes Scheduler.Do they plan to deprecate
podAffinity
/podAntiAffinity
? It has been mentioned, but no concrete action toward it.Or do they plan to improve them? They seem to be some activity in this direction (e.g. kubernetes/enhancements#2249), thus should Karpenter plan to actually support them? (And update the doc to something like "Karpenter doesn't support them for the moment (You can follow their consideration by subscribing to #942).")
TL;DR For this recommendation, imho the doc should have:
I may still be wrong about the why, but I hope to use this PR to get clarification for myself and everyone else.
3. Does this change impact docs?
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.