Skip to content

Commit

Permalink
Merge pull request #521 from pliurh/release-4.7
Browse files Browse the repository at this point in the history
[release-4.7] Bug 1960103: Find the MCP based on the owner of node's desired MC
  • Loading branch information
openshift-merge-robot authored Jun 17, 2021
2 parents 0401104 + d8a2a16 commit 8bb7170
Showing 1 changed file with 16 additions and 15 deletions.
31 changes: 16 additions & 15 deletions pkg/daemon/daemon.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import (
sninformer "github.com/k8snetworkplumbingwg/sriov-network-operator/pkg/client/informers/externalversions"
"github.com/k8snetworkplumbingwg/sriov-network-operator/pkg/utils"
mcfgv1 "github.com/openshift/machine-config-operator/pkg/apis/machineconfiguration.openshift.io/v1"
daemonconsts "github.com/openshift/machine-config-operator/pkg/daemon/constants"
mcclientset "github.com/openshift/machine-config-operator/pkg/generated/clientset/versioned"
mcfginformers "github.com/openshift/machine-config-operator/pkg/generated/informers/externalversions"
)
Expand Down Expand Up @@ -513,8 +514,10 @@ func (dn *Daemon) nodeStateSyncHandler(generation int64) error {
}
return nil
}
if err = dn.getNodeMachinePool(); err != nil {
return err
if utils.ClusterType == utils.ClusterTypeOpenshift {
if err = dn.getNodeMachinePool(); err != nil {
return err
}
}

if reqDrain && !dn.disableDrain {
Expand Down Expand Up @@ -750,25 +753,23 @@ func (dn *Daemon) annotateNode(node, value string) error {
}

func (dn *Daemon) getNodeMachinePool() error {
mcpList, err := dn.mcClient.MachineconfigurationV1().MachineConfigPools().List(context.TODO(), metav1.ListOptions{})
desiredConfig, ok := dn.node.Annotations[daemonconsts.DesiredMachineConfigAnnotationKey]
if !ok {
glog.Error("getNodeMachinePool(): Failed to find the the desiredConfig Annotation")
return fmt.Errorf("getNodeMachinePool(): Failed to find the the desiredConfig Annotation")
}
mc, err := dn.mcClient.MachineconfigurationV1().MachineConfigs().Get(context.TODO(), desiredConfig, metav1.GetOptions{})
if err != nil {
glog.Errorf("getNodeMachinePool(): Failed to list Machine Config Pools: %v", err)
glog.Errorf("getNodeMachinePool(): Failed to get the desired Machine Config: %v", err)
return err
}
var mcp mcfgv1.MachineConfigPool
for _, mcp = range mcpList.Items {
selector, err := metav1.LabelSelectorAsSelector(mcp.Spec.NodeSelector)
if err != nil {
glog.Errorf("getNodeMachinePool(): Machine Config Pool %s invalid label selector: %v", mcp.GetName(), err)
return err
}

if selector.Matches(labels.Set(dn.node.Labels)) {
dn.mcpName = mcp.GetName()
glog.Infof("getNodeMachinePool(): find node in MCP %s", dn.mcpName)
for _, owner := range mc.OwnerReferences {
if owner.Kind == "MachineConfigPool" {
dn.mcpName = owner.Name
return nil
}
}
glog.Error("getNodeMachinePool(): Failed to find the MCP of the node")
return fmt.Errorf("getNodeMachinePool(): Failed to find the MCP of the node")
}

Expand Down

0 comments on commit 8bb7170

Please sign in to comment.