-
Notifications
You must be signed in to change notification settings - Fork 34
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
extract namespace from network annotation when checking for kubevirt related pod instance #141
Conversation
/hold |
@@ -323,14 +323,14 @@ func (p *PoolManager) IsKubevirtEnabled() bool { | |||
return p.isKubevirt | |||
} | |||
|
|||
func (p *PoolManager) isRelatedToKubevirt(pod *corev1.Pod) bool { | |||
func (p *PoolManager) isRelatedToKubevirt(pod *corev1.Pod, kubevirtObjectNamespace string) bool { |
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.
This is no longer kubevirtObject right ? since we take it from Networks, I would say to name this namespace
so we hidde where is comming from.
@@ -348,6 +358,18 @@ func (p *PoolManager) isRelatedToKubevirt(pod *corev1.Pod) bool { | |||
return false | |||
} | |||
|
|||
//making sure that all networks have the same namespace, otherwise returning error. | |||
func (p *PoolManager) selectNamespaceFromNetworks(networks []*multus.NetworkSelectionElement) (string, bool) { |
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.
This can be a receiver free function we don't use PoolManager state
/lgtm |
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.
The issue has to be explained in the commit
// we need to receive the namespace from the network annotation | ||
namespace, ok := selectNamespaceFromNetworks(networks) | ||
if !ok { | ||
log.V(1).Info("this pod has more than 1 namespace in its secondary networks, so will be considered as a regular pod") |
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.
How does this work? Any pod or VM can request networks from any number of namespaces.
@@ -323,14 +324,23 @@ func (p *PoolManager) IsKubevirtEnabled() bool { | |||
return p.isKubevirt | |||
} | |||
|
|||
func (p *PoolManager) isRelatedToKubevirt(pod *corev1.Pod) bool { | |||
func (p *PoolManager) isRelatedToKubevirt(pod *corev1.Pod, networks []*multus.NetworkSelectionElement) bool { |
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.
Network namespaces are in no way related kubevirt. If you want to check if a Pod is owned by KubeVirt, you should check its labels/annotations/owner. I'm sure one of those will provide you what you seek, and reliably.
/approved cancel |
/approve cancel |
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
…elated pod instance when running a vm, a virt-launcher pod is spawned. This pod should be ignored by kubemacpool, since the mac was already allocated during the creation of the vm. This is implemented in isRelatedToKubevirt(). Specifically, it does this by checking there is a multus netwrok annotation, and that the vm self link is valid. The link required the vm's namespace. Currently, kubemacpool uses the pod's own namespace in order to construct this link. This doesn't work - because from some reason the pod isn't received with any namespace assigned to it. Hence, the pod to be treated as a standalone pod, and thus rejected. In this commit, we switch to taking the namespace from the pod's annotation, that consist the network's namespace. This is introduced with selectNamespaceFromNetworks(), which goes over the pod's multus.NetworkSelectionElement annotation (if exists), and extracts the namespace form there. We assume that in this case there could only be one namespace for all the multus networks. Signed-off-by: Ram Lavi <[email protected]>
@RamLavi: The following test failed, say
Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository. I understand the commands that are listed here. |
The proposed solution is not good enough for us. closing issue |
Signed-off-by: Ram Lavi [email protected]
What this PR does / why we need it:
short background:
when running a vm (
virtctl start <vm-nname>
) virt-controller creates the virt-launcher pod.Now, Although kubemacpool allocates mac to pods, it should disregard this pod (because the mac was already assigned to the vm). For this reason, kubmacpool uses isRelatedToKubevirt() to check if it needs to treat this pod as standalone or ignore it.
Specifically, isRelatedToKubevirt() does this by checking if the vm self link is valid.
Currently, kubemacpool uses the pod's own namespace in order to construct this link.
This doesn't work - because from some reason the pod isn't received with any namespace assigned to it. This causes the pod to be treated as a standalone pod, and thus rejected.
In this PR we switch to taking the namespace from the pod's annotation, that consist the network's namespace.
Special notes for your reviewer:
This PR fixes #140.
Release note: