-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
134 lines (114 loc) · 3.88 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
// main.go
package main
import (
"flag"
"fmt"
"os"
"strings"
"k8s.io/apimachinery/pkg/runtime"
clientgoscheme "k8s.io/client-go/kubernetes/scheme"
ctrl "sigs.k8s.io/controller-runtime"
"sigs.k8s.io/controller-runtime/pkg/healthz"
"sigs.k8s.io/controller-runtime/pkg/log/zap"
metricsserver "sigs.k8s.io/controller-runtime/pkg/metrics/server"
)
const leaderElectionId = "node-label-controller"
func main() {
var probesAddr string
var metricsAddr string
var pprofAddr string
var enableLeaderElection bool
var labelsStr string
var annotationsStr string
var cloudProvider string
var jsonLogs bool
logger := ctrl.Log.WithName("main")
flag.StringVar(&probesAddr, "probes-addr", ":8080", "The address the /readyz and /healthz probes endpoint binds to.")
flag.StringVar(&metricsAddr, "metrics-addr", ":8081", "The address the metric endpoint binds to.")
flag.StringVar(&pprofAddr, "pprof-addr", "", "The address the pprof server endpoint binds to.")
flag.BoolVar(&enableLeaderElection, "enable-leader-election", false, "Enable leader election.")
flag.StringVar(&labelsStr, "labels", "", "Comma-separated list of label keys to sync")
flag.StringVar(&annotationsStr, "annotations", "", "Comma-separated list of annotation keys to sync")
flag.StringVar(&cloudProvider, "cloud", "", "Cloud provider (aws or gcp)")
flag.BoolVar(&jsonLogs, "json", false, "Output logs in JSON format")
flag.Parse()
// setup logger. Use development mode by default or json output if --json is set
var opts []zap.Opts
opts = append(opts, zap.UseDevMode(!jsonLogs))
if jsonLogs {
opts = append(opts, zap.JSONEncoder())
}
ctrl.SetLogger(zap.New(opts...))
// validate flags
if labelsStr == "" && annotationsStr == "" {
logger.Error(fmt.Errorf("either --labels or --annotations is required"), "unable to start manager")
os.Exit(1)
}
var labels []string
if labelsStr != "" {
labels = strings.Split(labelsStr, ",")
logger.Info("Label keys to sync", "labelKeys", labels)
}
var annotations []string
if annotationsStr != "" {
annotations = strings.Split(annotationsStr, ",")
logger.Info("Annotation keys to sync", "annotationKeys", annotations)
}
if cloudProvider != "aws" && cloudProvider != "gcp" {
logger.Error(fmt.Errorf("cloud-provider must be either 'aws' or 'gcp'"), "unable to start manager")
os.Exit(1)
}
// get a kubeconfig for the manager to use to access the k8s API:
cfg, err := ctrl.GetConfig()
if err != nil {
logger.Error(err, "unable to get kubeconfig")
os.Exit(1)
}
// configure the controller-runtime manager
scheme := runtime.NewScheme()
_ = clientgoscheme.AddToScheme(scheme)
mgr, err := ctrl.NewManager(cfg, ctrl.Options{
Scheme: scheme,
HealthProbeBindAddress: probesAddr,
Metrics: metricsserver.Options{
BindAddress: metricsAddr,
},
PprofBindAddress: pprofAddr,
LeaderElection: enableLeaderElection,
LeaderElectionID: leaderElectionId,
})
if err != nil {
logger.Error(err, "unable to start manager")
os.Exit(1)
}
// setup /healthz and /readyz checks on the manager
if err := mgr.AddHealthzCheck("healthz", healthz.Ping); err != nil {
logger.Error(err, "unable to set up health check")
os.Exit(1)
}
if err := mgr.AddReadyzCheck("readyz", healthz.Ping); err != nil {
logger.Error(err, "unable to set up ready check")
os.Exit(1)
}
ctx := ctrl.SetupSignalHandler()
// setup our controller and start it
controller := &NodeLabelController{
Client: mgr.GetClient(),
Labels: labels,
Annotations: annotations,
Cloud: cloudProvider,
}
if err := controller.SetupCloudProvider(ctx); err != nil {
logger.Error(err, "unable to setup cloud provider")
os.Exit(1)
}
if err = controller.SetupWithManager(mgr); err != nil {
logger.Error(err, "unable to create controller")
os.Exit(1)
}
logger.Info("starting")
if err := mgr.Start(ctx); err != nil {
logger.Error(err, "problem starting manager")
os.Exit(1)
}
}