Skip to content

Commit d84ed50

Browse files
wojtek-tmfojtik
authored andcommitted
UPSTREAM: 53793: User separate client for leader election in scheduler
1 parent 3052f36 commit d84ed50

File tree

2 files changed

+12
-12
lines changed

2 files changed

+12
-12
lines changed

plugin/cmd/kube-scheduler/app/configurator.go

+6-6
Original file line numberDiff line numberDiff line change
@@ -56,22 +56,22 @@ func createRecorder(kubecli *clientset.Clientset, s *options.SchedulerServer) re
5656
return eventBroadcaster.NewRecorder(api.Scheme, v1.EventSource{Component: s.SchedulerName})
5757
}
5858

59-
func createClient(s *options.SchedulerServer) (*clientset.Clientset, error) {
59+
func createClients(s *options.SchedulerServer) (*clientset.Clientset, *clientset.Clientset, error) {
6060
kubeconfig, err := clientcmd.BuildConfigFromFlags(s.Master, s.Kubeconfig)
6161
if err != nil {
62-
return nil, fmt.Errorf("unable to build config from flags: %v", err)
62+
return nil, nil, fmt.Errorf("unable to build config from flags: %v", err)
6363
}
6464

6565
kubeconfig.ContentType = s.ContentType
6666
// Override kubeconfig qps/burst settings from flags
6767
kubeconfig.QPS = s.KubeAPIQPS
6868
kubeconfig.Burst = int(s.KubeAPIBurst)
69-
70-
cli, err := clientset.NewForConfig(restclient.AddUserAgent(kubeconfig, "leader-election"))
69+
kubeClient, err := clientset.NewForConfig(restclient.AddUserAgent(kubeconfig, "scheduler"))
7170
if err != nil {
72-
return nil, fmt.Errorf("invalid API configuration: %v", err)
71+
glog.Fatalf("Invalid API configuration: %v", err)
7372
}
74-
return cli, nil
73+
leaderElectionClient := clientset.NewForConfigOrDie(restclient.AddUserAgent(kubeconfig, "leader-election"))
74+
return kubeClient, leaderElectionClient, nil
7575
}
7676

7777
// CreateScheduler encapsulates the entire creation of a runnable scheduler.

plugin/cmd/kube-scheduler/app/server.go

+6-6
Original file line numberDiff line numberDiff line change
@@ -66,20 +66,20 @@ through the API as necessary.`,
6666

6767
// Run runs the specified SchedulerServer. This should never exit.
6868
func Run(s *options.SchedulerServer) error {
69-
kubecli, err := createClient(s)
69+
kubeClient, leaderElectionClient, err := createClients(s)
7070
if err != nil {
7171
return fmt.Errorf("unable to create kube client: %v", err)
7272
}
7373

74-
recorder := createRecorder(kubecli, s)
74+
recorder := createRecorder(kubeClient, s)
7575

76-
informerFactory := informers.NewSharedInformerFactory(kubecli, 0)
76+
informerFactory := informers.NewSharedInformerFactory(kubeClient, 0)
7777
// cache only non-terminal pods
78-
podInformer := factory.NewPodInformer(kubecli, 0)
78+
podInformer := factory.NewPodInformer(kubeClient, 0)
7979

8080
sched, err := CreateScheduler(
8181
s,
82-
kubecli,
82+
kubeClient,
8383
informerFactory.Core().V1().Nodes(),
8484
podInformer,
8585
informerFactory.Core().V1().PersistentVolumes(),
@@ -124,7 +124,7 @@ func Run(s *options.SchedulerServer) error {
124124
rl, err := resourcelock.New(s.LeaderElection.ResourceLock,
125125
s.LockObjectNamespace,
126126
s.LockObjectName,
127-
kubecli.CoreV1(),
127+
leaderElectionClient.CoreV1(),
128128
resourcelock.ResourceLockConfig{
129129
Identity: id,
130130
EventRecorder: recorder,

0 commit comments

Comments
 (0)