Skip to content

Commit

Permalink
Allow customization of client-go throttling (#525)
Browse files Browse the repository at this point in the history
* Allow customization of client-go throttling

This allows customization of the client-side throttling in client-go and
sets a higher initial default.
It is necessary for bigger setups with many domachines.

The approach and naming of the flags are taken 1:1 from cluster API to
keep things consistent.

* Remove default values form flag help

This is already done automatically by the flags package.
  • Loading branch information
gottwald authored Oct 5, 2023
1 parent d3c18aa commit c4d835c
Showing 1 changed file with 9 additions and 1 deletion.
10 changes: 9 additions & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ var (
profilerAddress string
webhookPort int
enableLeaderElection bool
restConfigQPS float32
restConfigBurst int
)

func initFlags(fs *pflag.FlagSet) {
Expand All @@ -95,6 +97,8 @@ func initFlags(fs *pflag.FlagSet) {
fs.DurationVar(&syncPeriod, "sync-period", 10*time.Minute, "The minimum interval at which watched resources are reconciled (e.g. 10m)")
fs.IntVar(&webhookPort, "webhook-port", 9443, "Webhook Server port, disabled by default. When enabled, the manager will only work as webhook server, no reconcilers are installed.")
fs.DurationVar(&reconcileTimeout, "reconcile-timeout", reconciler.DefaultLoopTimeout, "The maximum duration a reconcile loop can run (e.g. 90m)")
fs.Float32Var(&restConfigQPS, "kube-api-qps", 20, "Maximum queries per second from the controller client to the Kubernetes API server.")
fs.IntVar(&restConfigBurst, "kube-api-burst", 30, "Maximum number of queries that should be allowed in one burst from the controller client to the Kubernetes API server.")
}

func main() {
Expand Down Expand Up @@ -134,7 +138,11 @@ func main() {
BurstSize: 100,
})

mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{
restConfig := ctrl.GetConfigOrDie()
restConfig.QPS = restConfigQPS
restConfig.Burst = restConfigBurst

mgr, err := ctrl.NewManager(restConfig, ctrl.Options{
Scheme: scheme,
MetricsBindAddress: metricsAddr,
LeaderElection: enableLeaderElection,
Expand Down

0 comments on commit c4d835c

Please sign in to comment.