add EndpointSlice consumer helper functions #124777
Labels
priority/important-longterm
Important over the long term, but may not be staffed and/or may need multiple releases to complete.
sig/network
Categorizes an issue or PR as relevant to SIG Network.
triage/accepted
Indicates an issue or PR is ready to be actively worked on.
As discussed in the SIG Network meeting on May 9, we should provide "EndpointSlice helpers" to help people get away from Endpoints (without using EndpointSlices in a naive way that breaks for large services).
In particular, we want something that acts sort of like an
Informer
/Lister
, but where it deals with merging together multiple slices for the same service, so that, eg, if a service has 3 slices, and you do aGet
on that service, you get all of the endpoints across all three slices, and if 1 of the slices gets updated, you get anUpdated
event that includes the new combined set of endpoints, not just the endpoints for that one slice.(I'm not totally sure exactly what this API should look like. One possibility would be that
Get
would return a[]*discoveryv1.EndpointSlice
rather than a single*discoveryv1.EndpointSlice
. Though this would mean that when endpoints were being moved between slices, there would be temporary states where a single endpoint appeared in two different slices. Another possibility would be to have it synthesize fakeEndpointSlice
objects that just ignored the normal maximums and included all of the endpoints from across all of the slices (with the cache code dealing with de-duping). Though, actually, that doesn't work, because the different slices might have differentPorts
, so you'd still need to return an array of slices. So maybe we do want the first idea, just with a prominent warning that duplicates may exist.)kube-proxy's
EndpointSliceCache
may provide a starting point, though it's too tied to other internal kube-proxy APIs to actually be useful as-is.The code should go in some staged repo. I guess maybe
k8s.io/endpointslice
would be an obvious place? (It's currently only EndpointSlice controller code, but it could have EndpointSlice consumers too?) If not there, then maybek8s.io/component-helpers
./sig network
/priority important-longterm
/triage accepted
/cc @robscott
The text was updated successfully, but these errors were encountered: