diff --git a/installer/helm/chart/volcano/templates/controllers.yaml b/installer/helm/chart/volcano/templates/controllers.yaml index 6fa8a96cd3..1fe85fd757 100644 --- a/installer/helm/chart/volcano/templates/controllers.yaml +++ b/installer/helm/chart/volcano/templates/controllers.yaml @@ -72,10 +72,10 @@ rules: resources: ["networkpolicies"] verbs: ["get", "create", "delete"] - apiGroups: ["apps"] - resources: ["daemonsets", "statefulsets"] + resources: ["daemonsets"] verbs: ["get"] - apiGroups: ["apps"] - resources: ["replicasets"] + resources: ["replicasets", "statefulsets"] verbs: ["get", "list", "watch"] - apiGroups: ["batch"] resources: ["jobs"] diff --git a/installer/volcano-development.yaml b/installer/volcano-development.yaml index 1adc0dda5e..4874f35671 100644 --- a/installer/volcano-development.yaml +++ b/installer/volcano-development.yaml @@ -4304,10 +4304,10 @@ rules: resources: ["networkpolicies"] verbs: ["get", "create", "delete"] - apiGroups: ["apps"] - resources: ["daemonsets", "statefulsets"] + resources: ["daemonsets"] verbs: ["get"] - apiGroups: ["apps"] - resources: ["replicasets"] + resources: ["replicasets", "statefulsets"] verbs: ["get", "list", "watch"] - apiGroups: ["batch"] resources: ["jobs"] diff --git a/pkg/controllers/podgroup/pg_controller.go b/pkg/controllers/podgroup/pg_controller.go index 003e150da7..12cfd4a01f 100644 --- a/pkg/controllers/podgroup/pg_controller.go +++ b/pkg/controllers/podgroup/pg_controller.go @@ -51,6 +51,7 @@ type pgcontroller struct { podInformer coreinformers.PodInformer pgInformer schedulinginformer.PodGroupInformer rsInformer appinformers.ReplicaSetInformer + stsInformer appinformers.StatefulSetInformer informerFactory informers.SharedInformerFactory vcInformerFactory vcinformer.SharedInformerFactory @@ -64,7 +65,8 @@ type pgcontroller struct { pgSynced func() bool // A store of replicaset - rsSynced func() bool + rsSynced func() bool + stsSynced func() bool queue workqueue.RateLimitingInterface @@ -112,6 +114,13 @@ func (pg *pgcontroller) Initialize(opt *framework.ControllerOption) error { AddFunc: pg.addReplicaSet, UpdateFunc: pg.updateReplicaSet, }) + + pg.stsInformer = pg.informerFactory.Apps().V1().StatefulSets() + pg.stsSynced = pg.stsInformer.Informer().HasSynced + pg.stsInformer.Informer().AddEventHandler(cache.ResourceEventHandlerFuncs{ + AddFunc: pg.addStatefulSet, + UpdateFunc: pg.updateStatefulSet, + }) } return nil } diff --git a/pkg/controllers/podgroup/pg_controller_handler.go b/pkg/controllers/podgroup/pg_controller_handler.go index 12541d85a3..760142f0b8 100644 --- a/pkg/controllers/podgroup/pg_controller_handler.go +++ b/pkg/controllers/podgroup/pg_controller_handler.go @@ -105,6 +105,26 @@ func (pg *pgcontroller) updateReplicaSet(oldObj, newObj interface{}) { pg.addReplicaSet(newObj) } +func (pg *pgcontroller) addStatefulSet(obj interface{}) { + sts, ok := obj.(*appsv1.StatefulSet) + if !ok { + klog.Errorf("Failed to convert %v to appsv1.StatefulSet", obj) + return + } + + if *sts.Spec.Replicas == 0 { + pgName := batchv1alpha1.PodgroupNamePrefix + string(sts.UID) + err := pg.vcClient.SchedulingV1beta1().PodGroups(sts.Namespace).Delete(context.TODO(), pgName, metav1.DeleteOptions{}) + if err != nil && !apierrors.IsNotFound(err) { + klog.Errorf("Failed to delete PodGroup <%s/%s>: %v", sts.Namespace, pgName, err) + } + } +} + +func (pg *pgcontroller) updateStatefulSet(oldObj, newObj interface{}) { + pg.addStatefulSet(newObj) +} + func (pg *pgcontroller) updatePodAnnotations(pod *v1.Pod, pgName string) error { if pod.Annotations == nil { pod.Annotations = make(map[string]string)