-
Notifications
You must be signed in to change notification settings - Fork 9
Support for headless service #14
Comments
Hi @adihorowitz , thank you for the report. Multus-service does not support headless service as you noted. To support headless service, it requires to change Kubernetes (not multus-service, yeah. actually Kubernetes endpoint/endpointslice controller) to skip to add Pods IP address (i.e. eth0 IP address of Pod) into endpoint/endpointslice. Currently multus-service is designed to utilize Kubernetes resource as much as possible, hence multus-service utilize Kubernetes endpointslice, Kubernetes service object and Kubernetes well-known label, But still now, Kubernetes endpoint/endpointsclice controller automatically add eth0's IP address into endpoint/endpoint slice and this IP address is automatically added into CoreDNS for headless service. So if you try headless service with multus-service, CoreDNS may return eth0 IP address, added by Kubernetes controller. That is why multus-service does not support headless service. To support headless service, we need to find a way to prevent Kubernetes controller to add eth0 IP address into endpointslice, however, currently Kubernetes does not provide a way to do that. There are several activities related, such as kubernetes-retired/kpng#349 so let's see. |
Hi @s1061123, I was trying to work-around this issue by configuring an init container to query the DNS server, and keep only the secondary IP addresses (then pass the chosen IP to the main container). But I suspect that in the very beginning, there could be a situation where the coreDNS will return a DNS record that includes only the primary address - because the second endpointslice which is managed by multus-service-controller hasn't been created yet (a "race-condition" kind of scenario). What do you think? Is my explanation seems reasonable? |
I'm not clear what you said yet. When multus-service (i.e. Kubernetes service with label) is created, at that time, multus interface endpointslices are created by multus-service-controller (as you told) and primary interface is also created by kubernetes endpointslice controller. So your situation seems weird and it seems to be bug (I mean correct multus-service should have both). Could you please how to repro that? (i.e. there is only primary interface in endpointslice) |
Yes, the multus-service eventually will have both multus-controlled endpointslice and k8s-controlled endpointslice. But I wonder if there could be some very short amount of time where one of the endpointslices were configured and the other hasn't been configured yet (it is still in the process of configuration by the controller). In this short amount of time, if the init container queries the DNS server, the coreDNS will return only the primary network IP taken from the first endpointslice. |
I see. yeah, we need a time to add endpointslices but it is expected. We may change some timer value for tuning, but we cannot add endpointslice with Pod IP before its pod is launched (because we cannot get pod IP before the pod's launch). |
Sure. Just wanted to get your opinion about my speculation - that the reason for the DNS to (sometimes) return only the primary IP is that it doesn't "wait" for the multus-controlled endpointslice to be ready. |
Right. Let me keep in mind this and try to tune the parameters of multus-service-controller. Thank you for the feedback! |
Let me also mention that even though secondary network interface endpointslices are added, CoreDNS may return primary network interface IP address because CoreDNS do round-robin selection for IP in the endpointslice list (which contains parimary network interface IP address as well as secondary network interface address). |
@adihorowitz just FYI (see above) |
Thanks. I don't use the CoreDNS round-robin, my client gets the set of IP addresses and does the load-balance locally. |
Hello,
We are currently working on deploying RDMA-based applications in the Kubernetes cluster. RDMA runs over secondary-network interfaces, which makes multus-service very useful for us. The problem is that we must use headless type service for RDMA communication (because RDMA doesn't work well with NAT). I see that multus-service doesn't yet support headless services. Do you plan to support it? If yes, do you have an estimation of when this will be supported?
The text was updated successfully, but these errors were encountered: