add feature enablement options to recommendedoptions
This commit is contained in:
parent
8c39f8c871
commit
2e34520350
|
@ -0,0 +1,62 @@
|
||||||
|
/*
|
||||||
|
Copyright 2017 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package options
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/spf13/pflag"
|
||||||
|
|
||||||
|
"k8s.io/apiserver/pkg/server"
|
||||||
|
)
|
||||||
|
|
||||||
|
type FeatureOptions struct {
|
||||||
|
EnableGarbageCollection bool
|
||||||
|
EnableProfiling bool
|
||||||
|
EnableContentionProfiling bool
|
||||||
|
EnableSwaggerUI bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewFeatureOptions() *FeatureOptions {
|
||||||
|
defaults := server.NewConfig()
|
||||||
|
|
||||||
|
return &FeatureOptions{
|
||||||
|
EnableGarbageCollection: defaults.EnableGarbageCollection,
|
||||||
|
EnableProfiling: defaults.EnableProfiling,
|
||||||
|
EnableContentionProfiling: defaults.EnableContentionProfiling,
|
||||||
|
EnableSwaggerUI: defaults.EnableSwaggerUI,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *FeatureOptions) AddFlags(fs *pflag.FlagSet) {
|
||||||
|
fs.BoolVar(&o.EnableGarbageCollection, "enable-garbage-collector", o.EnableGarbageCollection, ""+
|
||||||
|
"Enables the generic garbage collector. MUST be synced with the corresponding flag "+
|
||||||
|
"of the kube-controller-manager.")
|
||||||
|
fs.BoolVar(&o.EnableProfiling, "profiling", o.EnableProfiling,
|
||||||
|
"Enable profiling via web interface host:port/debug/pprof/")
|
||||||
|
fs.BoolVar(&o.EnableContentionProfiling, "contention-profiling", o.EnableContentionProfiling,
|
||||||
|
"Enable contention profiling. Requires --profiling to be set to work.")
|
||||||
|
fs.BoolVar(&o.EnableSwaggerUI, "enable-swagger-ui", o.EnableSwaggerUI,
|
||||||
|
"Enables swagger ui on the apiserver at /swagger-ui")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *FeatureOptions) ApplyTo(c *server.Config) error {
|
||||||
|
c.EnableGarbageCollection = o.EnableGarbageCollection
|
||||||
|
c.EnableProfiling = o.EnableProfiling
|
||||||
|
c.EnableContentionProfiling = o.EnableContentionProfiling
|
||||||
|
c.EnableSwaggerUI = o.EnableSwaggerUI
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
|
@ -31,6 +31,7 @@ type RecommendedOptions struct {
|
||||||
Authentication *DelegatingAuthenticationOptions
|
Authentication *DelegatingAuthenticationOptions
|
||||||
Authorization *DelegatingAuthorizationOptions
|
Authorization *DelegatingAuthorizationOptions
|
||||||
Audit *AuditLogOptions
|
Audit *AuditLogOptions
|
||||||
|
Features *FeatureOptions
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewRecommendedOptions(scheme *runtime.Scheme) *RecommendedOptions {
|
func NewRecommendedOptions(scheme *runtime.Scheme) *RecommendedOptions {
|
||||||
|
@ -40,6 +41,7 @@ func NewRecommendedOptions(scheme *runtime.Scheme) *RecommendedOptions {
|
||||||
Authentication: NewDelegatingAuthenticationOptions(),
|
Authentication: NewDelegatingAuthenticationOptions(),
|
||||||
Authorization: NewDelegatingAuthorizationOptions(),
|
Authorization: NewDelegatingAuthorizationOptions(),
|
||||||
Audit: NewAuditLogOptions(),
|
Audit: NewAuditLogOptions(),
|
||||||
|
Features: NewFeatureOptions(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,6 +51,7 @@ func (o *RecommendedOptions) AddFlags(fs *pflag.FlagSet) {
|
||||||
o.Authentication.AddFlags(fs)
|
o.Authentication.AddFlags(fs)
|
||||||
o.Authorization.AddFlags(fs)
|
o.Authorization.AddFlags(fs)
|
||||||
o.Audit.AddFlags(fs)
|
o.Audit.AddFlags(fs)
|
||||||
|
o.Features.AddFlags(fs)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (o *RecommendedOptions) ApplyTo(config *server.Config) error {
|
func (o *RecommendedOptions) ApplyTo(config *server.Config) error {
|
||||||
|
@ -64,6 +67,9 @@ func (o *RecommendedOptions) ApplyTo(config *server.Config) error {
|
||||||
if err := o.Audit.ApplyTo(config); err != nil {
|
if err := o.Audit.ApplyTo(config); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
if err := o.Features.ApplyTo(config); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,10 +43,6 @@ type ServerRunOptions struct {
|
||||||
// to set it to "application/vnd.kubernetes.protobuf".
|
// to set it to "application/vnd.kubernetes.protobuf".
|
||||||
DefaultStorageMediaType string
|
DefaultStorageMediaType string
|
||||||
DeleteCollectionWorkers int
|
DeleteCollectionWorkers int
|
||||||
EnableGarbageCollection bool
|
|
||||||
EnableProfiling bool
|
|
||||||
EnableContentionProfiling bool
|
|
||||||
EnableSwaggerUI bool
|
|
||||||
EnableWatchCache bool
|
EnableWatchCache bool
|
||||||
ExternalHost string
|
ExternalHost string
|
||||||
MaxRequestsInFlight int
|
MaxRequestsInFlight int
|
||||||
|
@ -63,9 +59,6 @@ func NewServerRunOptions() *ServerRunOptions {
|
||||||
AdmissionControl: "AlwaysAdmit",
|
AdmissionControl: "AlwaysAdmit",
|
||||||
DefaultStorageMediaType: "application/json",
|
DefaultStorageMediaType: "application/json",
|
||||||
DeleteCollectionWorkers: 1,
|
DeleteCollectionWorkers: 1,
|
||||||
EnableGarbageCollection: defaults.EnableGarbageCollection,
|
|
||||||
EnableProfiling: defaults.EnableProfiling,
|
|
||||||
EnableContentionProfiling: false,
|
|
||||||
EnableWatchCache: true,
|
EnableWatchCache: true,
|
||||||
MaxRequestsInFlight: defaults.MaxRequestsInFlight,
|
MaxRequestsInFlight: defaults.MaxRequestsInFlight,
|
||||||
MaxMutatingRequestsInFlight: defaults.MaxMutatingRequestsInFlight,
|
MaxMutatingRequestsInFlight: defaults.MaxMutatingRequestsInFlight,
|
||||||
|
@ -76,10 +69,6 @@ func NewServerRunOptions() *ServerRunOptions {
|
||||||
// ApplyOptions applies the run options to the method receiver and returns self
|
// ApplyOptions applies the run options to the method receiver and returns self
|
||||||
func (s *ServerRunOptions) ApplyTo(c *server.Config) error {
|
func (s *ServerRunOptions) ApplyTo(c *server.Config) error {
|
||||||
c.CorsAllowedOriginList = s.CorsAllowedOriginList
|
c.CorsAllowedOriginList = s.CorsAllowedOriginList
|
||||||
c.EnableGarbageCollection = s.EnableGarbageCollection
|
|
||||||
c.EnableProfiling = s.EnableProfiling
|
|
||||||
c.EnableContentionProfiling = s.EnableContentionProfiling
|
|
||||||
c.EnableSwaggerUI = s.EnableSwaggerUI
|
|
||||||
c.ExternalAddress = s.ExternalHost
|
c.ExternalAddress = s.ExternalHost
|
||||||
c.MaxRequestsInFlight = s.MaxRequestsInFlight
|
c.MaxRequestsInFlight = s.MaxRequestsInFlight
|
||||||
c.MaxMutatingRequestsInFlight = s.MaxMutatingRequestsInFlight
|
c.MaxMutatingRequestsInFlight = s.MaxMutatingRequestsInFlight
|
||||||
|
@ -146,18 +135,6 @@ func (s *ServerRunOptions) AddUniversalFlags(fs *pflag.FlagSet) {
|
||||||
fs.IntVar(&s.DeleteCollectionWorkers, "delete-collection-workers", s.DeleteCollectionWorkers,
|
fs.IntVar(&s.DeleteCollectionWorkers, "delete-collection-workers", s.DeleteCollectionWorkers,
|
||||||
"Number of workers spawned for DeleteCollection call. These are used to speed up namespace cleanup.")
|
"Number of workers spawned for DeleteCollection call. These are used to speed up namespace cleanup.")
|
||||||
|
|
||||||
fs.BoolVar(&s.EnableGarbageCollection, "enable-garbage-collector", s.EnableGarbageCollection, ""+
|
|
||||||
"Enables the generic garbage collector. MUST be synced with the corresponding flag "+
|
|
||||||
"of the kube-controller-manager.")
|
|
||||||
|
|
||||||
fs.BoolVar(&s.EnableProfiling, "profiling", s.EnableProfiling,
|
|
||||||
"Enable profiling via web interface host:port/debug/pprof/")
|
|
||||||
fs.BoolVar(&s.EnableContentionProfiling, "contention-profiling", s.EnableContentionProfiling,
|
|
||||||
"Enable contention profiling. Requires --profiling to be set to work.")
|
|
||||||
|
|
||||||
fs.BoolVar(&s.EnableSwaggerUI, "enable-swagger-ui", s.EnableSwaggerUI,
|
|
||||||
"Enables swagger ui on the apiserver at /swagger-ui")
|
|
||||||
|
|
||||||
// TODO: enable cache in integration tests.
|
// TODO: enable cache in integration tests.
|
||||||
fs.BoolVar(&s.EnableWatchCache, "watch-cache", s.EnableWatchCache,
|
fs.BoolVar(&s.EnableWatchCache, "watch-cache", s.EnableWatchCache,
|
||||||
"Enable watch caching in the apiserver")
|
"Enable watch caching in the apiserver")
|
||||||
|
|
Loading…
Reference in New Issue