Skip to content

Commit

Permalink
Disable configuration hot reload (#2354)
Browse files Browse the repository at this point in the history
  • Loading branch information
swiatekm authored Nov 16, 2023
1 parent 9dc4417 commit 78e98e7
Show file tree
Hide file tree
Showing 5 changed files with 57 additions and 17 deletions.
18 changes: 18 additions & 0 deletions .chloggen/disable-hot-reload.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# One of 'breaking', 'deprecation', 'new_component', 'enhancement', 'bug_fix'
change_type: breaking

# The name of the component, or a single word describing the area of concern, (e.g. operator, target allocator, github action)
component: target allocator

# A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`).
note: Disable configuration hot reload

# One or more tracking issues related to the change
issues: [2032]

# (Optional) One or more lines of additional information to render under the primary note.
# These lines will be padded with 2 spaces and then inserted directly into the document.
# Use pipe (|) for multiline entries.
subtext: |
This feature can be re-enabled by passing the --reload-config flag to the target allocator.
However, this is deprecated and will be removed in an upcoming release.
6 changes: 6 additions & 0 deletions cmd/otel-allocator/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ type Config struct {
KubeConfigFilePath string `yaml:"kube_config_file_path,omitempty"`
ClusterConfig *rest.Config `yaml:"-"`
RootLogger logr.Logger `yaml:"-"`
ReloadConfig bool `yaml:"-"`
LabelSelector map[string]string `yaml:"label_selector,omitempty"`
PromConfig *promconfig.Config `yaml:"config"`
AllocationStrategy *string `yaml:"allocation_strategy,omitempty"`
Expand Down Expand Up @@ -110,6 +111,11 @@ func LoadFromCLI(target *Config, flagSet *pflag.FlagSet) error {
return err
}

target.ReloadConfig, err = getConfigReloadEnabled(flagSet)
if err != nil {
return err
}

return nil
}

Expand Down
6 changes: 6 additions & 0 deletions cmd/otel-allocator/config/flags.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ const (
listenAddrFlagName = "listen-addr"
prometheusCREnabledFlagName = "enable-prometheus-cr-watcher"
kubeConfigPathFlagName = "kubeconfig-path"
reloadConfigFlagName = "reload-config"
)

// We can't bind this flag to our FlagSet, so we need to handle it separately.
Expand All @@ -41,6 +42,7 @@ func getFlagSet(errorHandling pflag.ErrorHandling) *pflag.FlagSet {
flagSet.String(listenAddrFlagName, ":8080", "The address where this service serves.")
flagSet.Bool(prometheusCREnabledFlagName, false, "Enable Prometheus CRs as target sources")
flagSet.String(kubeConfigPathFlagName, filepath.Join(homedir.HomeDir(), ".kube", "config"), "absolute path to the KubeconfigPath file")
flagSet.Bool(reloadConfigFlagName, false, "Enable automatic configuration reloading. This functionality is deprecated and will be removed in a future release.")
zapFlagSet := flag.NewFlagSet("", flag.ErrorHandling(errorHandling))
zapCmdLineOpts.BindFlags(zapFlagSet)
flagSet.AddGoFlagSet(zapFlagSet)
Expand All @@ -62,3 +64,7 @@ func getListenAddr(flagSet *pflag.FlagSet) (string, error) {
func getPrometheusCREnabled(flagSet *pflag.FlagSet) (bool, error) {
return flagSet.GetBool(prometheusCREnabledFlagName)
}

func getConfigReloadEnabled(flagSet *pflag.FlagSet) (bool, error) {
return flagSet.GetBool(reloadConfigFlagName)
}
6 changes: 6 additions & 0 deletions cmd/otel-allocator/config/flags_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,12 @@ func TestFlagGetters(t *testing.T) {
expectedValue: true,
getterFunc: func(fs *pflag.FlagSet) (interface{}, error) { return getPrometheusCREnabled(fs) },
},
{
name: "GetConfigReloadEnabled",
flagArgs: []string{"--" + reloadConfigFlagName, "true"},
expectedValue: true,
getterFunc: func(fs *pflag.FlagSet) (interface{}, error) { return getConfigReloadEnabled(fs) },
},
{
name: "InvalidFlag",
flagArgs: []string{"--invalid-flag", "value"},
Expand Down
38 changes: 21 additions & 17 deletions cmd/otel-allocator/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -98,10 +98,12 @@ func main() {
setupLog.Error(collectorWatcherErr, "Unable to initialize collector watcher")
os.Exit(1)
}
fileWatcher, err = allocatorWatcher.NewFileWatcher(setupLog.WithName("file-watcher"), configFilePath)
if err != nil {
setupLog.Error(err, "Can't start the file watcher")
os.Exit(1)
if cfg.ReloadConfig {
fileWatcher, err = allocatorWatcher.NewFileWatcher(setupLog.WithName("file-watcher"), configFilePath)
if err != nil {
setupLog.Error(err, "Can't start the file watcher")
os.Exit(1)
}
}
signal.Notify(interrupts, os.Interrupt, syscall.SIGINT, syscall.SIGTERM)
defer close(interrupts)
Expand All @@ -126,19 +128,21 @@ func main() {
}
})
}
runGroup.Add(
func() error {
fileWatcherErr := fileWatcher.Watch(eventChan, errChan)
setupLog.Info("File watcher exited")
return fileWatcherErr
},
func(_ error) {
setupLog.Info("Closing file watcher")
fileWatcherErr := fileWatcher.Close()
if fileWatcherErr != nil {
setupLog.Error(fileWatcherErr, "file watcher failed to close")
}
})
if cfg.ReloadConfig {
runGroup.Add(
func() error {
fileWatcherErr := fileWatcher.Watch(eventChan, errChan)
setupLog.Info("File watcher exited")
return fileWatcherErr
},
func(_ error) {
setupLog.Info("Closing file watcher")
fileWatcherErr := fileWatcher.Close()
if fileWatcherErr != nil {
setupLog.Error(fileWatcherErr, "file watcher failed to close")
}
})
}
runGroup.Add(
func() error {
discoveryManagerErr := discoveryManager.Run()
Expand Down

0 comments on commit 78e98e7

Please sign in to comment.