30 lines
1.3 KiB
Go
30 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"os"
|
|
|
|
// Note that Kubernetes registers workqueue metrics to default prometheus Registry. And the registry will be
|
|
// initialized by the package 'k8s.io/apiserver/pkg/server'.
|
|
// See https://github.com/kubernetes/kubernetes/blob/release-1.26/staging/src/k8s.io/component-base/metrics/prometheus/workqueue/metrics.go#L25-L26
|
|
// But the controller-runtime registers workqueue metrics to its own Registry instead of default prometheus Registry.
|
|
// See https://github.com/kubernetes-sigs/controller-runtime/blob/release-0.14/pkg/metrics/workqueue.go#L24-L26
|
|
// However, global workqueue metrics factory will be only initialized once.
|
|
// See https://github.com/kubernetes/kubernetes/blob/release-1.26/staging/src/k8s.io/client-go/util/workqueue/metrics.go#L257-L261
|
|
// So this package should be initialized before 'k8s.io/apiserver/pkg/server', thus the internal registry of
|
|
// controller-runtime could be set first.
|
|
_ "sigs.k8s.io/controller-runtime/pkg/metrics"
|
|
|
|
apiserver "k8s.io/apiserver/pkg/server"
|
|
"k8s.io/component-base/cli"
|
|
_ "k8s.io/component-base/logs/json/register" // for JSON log format registration
|
|
|
|
"github.com/karmada-io/karmada/cmd/scheduler-estimator/app"
|
|
)
|
|
|
|
func main() {
|
|
ctx := apiserver.SetupSignalContext()
|
|
cmd := app.NewSchedulerEstimatorCommand(ctx)
|
|
code := cli.Run(cmd)
|
|
os.Exit(code)
|
|
}
|