|
| 1 | +package schedulerplugin |
| 2 | + |
| 3 | +import ( |
| 4 | + glog "k8s.io/klog" |
| 5 | + "tkestack.io/galaxy/pkg/api/galaxy/constant" |
| 6 | + "tkestack.io/galaxy/pkg/api/k8s/schedulerapi" |
| 7 | +) |
| 8 | + |
| 9 | +func fillNodeNameToMetaVictims(args *schedulerapi.ExtenderPreemptionArgs) { |
| 10 | + if len(args.NodeNameToVictims) != 0 && len(args.NodeNameToMetaVictims) == 0 { |
| 11 | + args.NodeNameToMetaVictims = map[string]*schedulerapi.MetaVictims{} |
| 12 | + for node, victim := range args.NodeNameToVictims { |
| 13 | + metaVictim := &schedulerapi.MetaVictims{ |
| 14 | + Pods: []*schedulerapi.MetaPod{}, |
| 15 | + NumPDBViolations: victim.NumPDBViolations, |
| 16 | + } |
| 17 | + for _, pod := range victim.Pods { |
| 18 | + metaPod := &schedulerapi.MetaPod{ |
| 19 | + UID: string(pod.UID), |
| 20 | + } |
| 21 | + metaVictim.Pods = append(metaVictim.Pods, metaPod) |
| 22 | + } |
| 23 | + args.NodeNameToMetaVictims[node] = metaVictim |
| 24 | + } |
| 25 | + } |
| 26 | +} |
| 27 | + |
| 28 | +func (p *FloatingIPPlugin) Preempt(args *schedulerapi.ExtenderPreemptionArgs) map[string]*schedulerapi.MetaVictims { |
| 29 | + fillNodeNameToMetaVictims(args) |
| 30 | + policy := parseReleasePolicy(&args.Pod.ObjectMeta) |
| 31 | + if policy == constant.ReleasePolicyPodDelete { |
| 32 | + return args.NodeNameToMetaVictims |
| 33 | + } |
| 34 | + subnetSet, err := p.getSubnet(args.Pod) |
| 35 | + if err != nil { |
| 36 | + glog.Errorf("unable to get pod subnets: %v", err) |
| 37 | + return args.NodeNameToMetaVictims |
| 38 | + } |
| 39 | + glog.V(4).Infof("subnet for pod %v is %v", args.Pod.Name, subnetSet) |
| 40 | + for nodeName := range args.NodeNameToMetaVictims { |
| 41 | + node, err := p.NodeLister.Get(nodeName) |
| 42 | + if err != nil { |
| 43 | + glog.Errorf("unable to list node: %v", err) |
| 44 | + delete(args.NodeNameToMetaVictims, nodeName) |
| 45 | + continue |
| 46 | + } |
| 47 | + subnet, err := p.getNodeSubnet(node) |
| 48 | + if err != nil { |
| 49 | + glog.Errorf("unable to get node %v subnet: %v", nodeName, err) |
| 50 | + delete(args.NodeNameToMetaVictims, nodeName) |
| 51 | + continue |
| 52 | + } |
| 53 | + if !subnetSet.Has(subnet.String()) { |
| 54 | + glog.V(4).Infof("remove node %v with subnet %v from victim", node.Name, subnet.String()) |
| 55 | + delete(args.NodeNameToMetaVictims, nodeName) |
| 56 | + } |
| 57 | + } |
| 58 | + return args.NodeNameToMetaVictims |
| 59 | +} |
0 commit comments