Skip to content

Commit

Permalink
Merge pull request kubernetes-sigs#11140 from Nordix/remove-deprecate…
Browse files Browse the repository at this point in the history
…d-code/sunnat

🌱 Remove previously deprecated --metrics-bind-addr flag
  • Loading branch information
k8s-ci-robot authored Sep 12, 2024
2 parents f9738ac + 6e02691 commit c4d1b8a
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 57 deletions.
2 changes: 1 addition & 1 deletion docs/book/src/reference/ports.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

Name | Port Number | Description |
--- | --- | ---
`metrics` | | Port that exposes the metrics. This can be customized by setting the `--metrics-bind-addr` flag when starting the manager. The default is to only listen on `localhost:8080`
`diagnostics-address` | | Port that exposes the metrics, the pprof endpoint and an endpoint to change the log level. This can be customized by setting the `--diagnostics-address` flag when starting the manager. The default port is `8443`.
`webhook` | `9443` | Webhook server port. To disable this set `--webhook-port` flag to `0`.
`health` | `9440` | Port that exposes the health endpoint. CThis can be customized by setting the `--health-addr` flag when starting the manager.
`profiler`| | Expose the pprof profiler. By default is not configured. Can set the `--profiler-address` flag. e.g. `--profiler-address 6060`
Expand Down
62 changes: 22 additions & 40 deletions util/flags/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,11 +47,6 @@ type ManagerOptions struct {
// Metrics Options
// These are used to configure the metrics server

// MetricsBindAddr is the field that stores the value of the --metrics-bind-addr flag.
// For further details, please see the description of the flag.
//
// Deprecated: This field will be removed in an upcoming release.
MetricsBindAddr string
// DiagnosticsAddress is the field that stores the value of the --diagnostics-address flag.
// For further details, please see the description of the flag.
DiagnosticsAddress string
Expand All @@ -75,11 +70,6 @@ func AddManagerOptions(fs *pflag.FlagSet, options *ManagerOptions) {
"Preferred values: "+strings.Join(tlsCipherPreferredValues, ", ")+". \n"+
"Insecure values: "+strings.Join(tlsCipherInsecureValues, ", ")+".")

fs.StringVar(&options.MetricsBindAddr, "metrics-bind-addr", "",
"The address the metrics endpoint binds to.")
_ = fs.MarkDeprecated("metrics-bind-addr", "Please use --diagnostics-address instead. To continue to serve "+
"metrics via http and without authentication/authorization set --insecure-diagnostics as well.")

fs.StringVar(&options.DiagnosticsAddress, "diagnostics-address", ":8443",
"The address the diagnostics endpoint binds to. Per default metrics are served via https and with"+
"authentication/authorization. To serve via http and without authentication/authorization set --insecure-diagnostics. "+
Expand Down Expand Up @@ -113,40 +103,32 @@ func GetManagerOptions(options ManagerOptions) ([]func(config *tls.Config), *met
})
}

// If the deprecated "--metrics-bind-addr" flag is set, continue to serve metrics via http
// If "--insecure-diagnostics" is set, serve metrics via http
// and without authentication/authorization.
if options.MetricsBindAddr != "" {
if options.InsecureDiagnostics {
metricsOptions = &metricsserver.Options{
BindAddress: options.MetricsBindAddr,
BindAddress: options.DiagnosticsAddress,
SecureServing: false,
}
} else {
// If "--insecure-diagnostics" is set, serve metrics via http
// and without authentication/authorization.
if options.InsecureDiagnostics {
metricsOptions = &metricsserver.Options{
BindAddress: options.DiagnosticsAddress,
SecureServing: false,
}
} else {
// If "--insecure-diagnostics" is not set, serve metrics via https
// and with authentication/authorization. As the endpoint is protected,
// we also serve pprof endpoints and an endpoint to change the log level.
metricsOptions = &metricsserver.Options{
BindAddress: options.DiagnosticsAddress,
SecureServing: true,
FilterProvider: filters.WithAuthenticationAndAuthorization,
ExtraHandlers: map[string]http.Handler{
// Add handler to dynamically change log level.
"/debug/flags/v": routes.StringFlagPutHandler(logs.GlogSetter),
// Add pprof handler.
"/debug/pprof/": http.HandlerFunc(pprof.Index),
"/debug/pprof/cmdline": http.HandlerFunc(pprof.Cmdline),
"/debug/pprof/profile": http.HandlerFunc(pprof.Profile),
"/debug/pprof/symbol": http.HandlerFunc(pprof.Symbol),
"/debug/pprof/trace": http.HandlerFunc(pprof.Trace),
},
TLSOpts: tlsOptions,
}
// If "--insecure-diagnostics" is not set, serve metrics via https
// and with authentication/authorization. As the endpoint is protected,
// we also serve pprof endpoints and an endpoint to change the log level.
metricsOptions = &metricsserver.Options{
BindAddress: options.DiagnosticsAddress,
SecureServing: true,
FilterProvider: filters.WithAuthenticationAndAuthorization,
ExtraHandlers: map[string]http.Handler{
// Add handler to dynamically change log level.
"/debug/flags/v": routes.StringFlagPutHandler(logs.GlogSetter),
// Add pprof handler.
"/debug/pprof/": http.HandlerFunc(pprof.Index),
"/debug/pprof/cmdline": http.HandlerFunc(pprof.Cmdline),
"/debug/pprof/profile": http.HandlerFunc(pprof.Profile),
"/debug/pprof/symbol": http.HandlerFunc(pprof.Symbol),
"/debug/pprof/trace": http.HandlerFunc(pprof.Trace),
},
TLSOpts: tlsOptions,
}
}

Expand Down
16 changes: 0 additions & 16 deletions util/flags/manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,22 +52,6 @@ func TestGetManagerOptions(t *testing.T) {
},
wantErr: true,
},
{
name: "valid tls + metrics bind addr",
managerOptions: ManagerOptions{
TLSMinVersion: "VersionTLS13",
TLSCipherSuites: []string{"TLS_AES_256_GCM_SHA384"},
MetricsBindAddr: ":8080",
},
wantTLSConfig: &tls.Config{
MinVersion: tls.VersionTLS13,
CipherSuites: []uint16{tls.TLS_AES_256_GCM_SHA384},
},
wantMetricsOptions: &metricsserver.Options{
BindAddress: ":8080",
},
wantErr: false,
},
{
name: "valid tls + insecure diagnostics + diagnostics address",
managerOptions: ManagerOptions{
Expand Down

0 comments on commit c4d1b8a

Please sign in to comment.