fix: paramtable cache cause dynamic config non-dynamic (#33473)

relate: https://github.com/milvus-io/milvus/issues/33461

Signed-off-by: aoiasd <zhicheng.yue@zilliz.com>
pull/33599/head
aoiasd 2024-06-04 11:39:46 +08:00 committed by GitHub
parent ac5e098e13
commit 2422084a29
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 45 additions and 1 deletions

View File

@ -411,7 +411,7 @@ func (mr *MilvusRoles) Run() {
} }
tracer.SetTracerProvider(exp, params.TraceCfg.SampleFraction.GetAsFloat()) tracer.SetTracerProvider(exp, params.TraceCfg.SampleFraction.GetAsFloat())
log.Info("Reset tracer finished", zap.String("Exporter", params.TraceCfg.Exporter.GetValue())) log.Info("Reset tracer finished", zap.String("Exporter", params.TraceCfg.Exporter.GetValue()), zap.Float64("SampleFraction", params.TraceCfg.SampleFraction.GetAsFloat()))
if paramtable.GetRole() == typeutil.QueryNodeRole || paramtable.GetRole() == typeutil.StandaloneRole { if paramtable.GetRole() == typeutil.QueryNodeRole || paramtable.GetRole() == typeutil.StandaloneRole {
initcore.InitTraceConfig(params) initcore.InitTraceConfig(params)

View File

@ -78,6 +78,9 @@ func (es EnvSource) GetSourceName() string {
return "EnvironmentSource" return "EnvironmentSource"
} }
func (es EnvSource) SetManager(m ConfigManager) {
}
func (es EnvSource) SetEventHandler(eh EventHandler) { func (es EnvSource) SetEventHandler(eh EventHandler) {
} }

View File

@ -24,6 +24,7 @@ import (
"sync" "sync"
"time" "time"
"github.com/samber/lo"
clientv3 "go.etcd.io/etcd/client/v3" clientv3 "go.etcd.io/etcd/client/v3"
"go.uber.org/zap" "go.uber.org/zap"
@ -44,6 +45,7 @@ type EtcdSource struct {
updateMu sync.Mutex updateMu sync.Mutex
configRefresher *refresher configRefresher *refresher
manager ConfigManager
} }
func NewEtcdSource(etcdInfo *EtcdInfo) (*EtcdSource, error) { func NewEtcdSource(etcdInfo *EtcdInfo) (*EtcdSource, error) {
@ -115,6 +117,12 @@ func (es *EtcdSource) Close() {
es.configRefresher.stop() es.configRefresher.stop()
} }
func (es *EtcdSource) SetManager(m ConfigManager) {
es.Lock()
defer es.Unlock()
es.manager = m
}
func (es *EtcdSource) SetEventHandler(eh EventHandler) { func (es *EtcdSource) SetEventHandler(eh EventHandler) {
es.configRefresher.SetEventHandler(eh) es.configRefresher.SetEventHandler(eh)
} }
@ -172,6 +180,9 @@ func (es *EtcdSource) update(configs map[string]string) error {
return err return err
} }
es.currentConfigs = configs es.currentConfigs = configs
if es.manager != nil {
es.manager.EvictCacheValueByFormat(lo.Map(events, func(event *Event, _ int) string { return event.Key })...)
}
es.Unlock() es.Unlock()
es.configRefresher.fireEvents(events...) es.configRefresher.fireEvents(events...)

View File

@ -22,6 +22,7 @@ import (
"sync" "sync"
"github.com/cockroachdb/errors" "github.com/cockroachdb/errors"
"github.com/samber/lo"
"github.com/spf13/cast" "github.com/spf13/cast"
"github.com/spf13/viper" "github.com/spf13/viper"
"go.uber.org/zap" "go.uber.org/zap"
@ -36,6 +37,7 @@ type FileSource struct {
updateMu sync.Mutex updateMu sync.Mutex
configRefresher *refresher configRefresher *refresher
manager ConfigManager
} }
func NewFileSource(fileInfo *FileInfo) *FileSource { func NewFileSource(fileInfo *FileInfo) *FileSource {
@ -91,6 +93,12 @@ func (fs *FileSource) Close() {
fs.configRefresher.stop() fs.configRefresher.stop()
} }
func (fs *FileSource) SetManager(m ConfigManager) {
fs.Lock()
defer fs.Unlock()
fs.manager = m
}
func (fs *FileSource) SetEventHandler(eh EventHandler) { func (fs *FileSource) SetEventHandler(eh EventHandler) {
fs.RWMutex.Lock() fs.RWMutex.Lock()
defer fs.RWMutex.Unlock() defer fs.RWMutex.Unlock()
@ -173,6 +181,9 @@ func (fs *FileSource) update(configs map[string]string) error {
return err return err
} }
fs.configs = configs fs.configs = configs
if fs.manager != nil {
fs.manager.EvictCacheValueByFormat(lo.Map(events, func(event *Event, _ int) string { return event.Key })...)
}
fs.Unlock() fs.Unlock()
fs.configRefresher.fireEvents(events...) fs.configRefresher.fireEvents(events...)

View File

@ -116,6 +116,16 @@ func (m *Manager) EvictCachedValue(key string) {
m.configCache.Remove(key) m.configCache.Remove(key)
} }
func (m *Manager) EvictCacheValueByFormat(keys ...string) {
set := typeutil.NewSet(keys...)
m.configCache.Range(func(key string, value interface{}) bool {
if set.Contain(formatKey(key)) {
m.configCache.Remove(key)
}
return true
})
}
func (m *Manager) GetConfig(key string) (string, error) { func (m *Manager) GetConfig(key string) (string, error) {
realKey := formatKey(key) realKey := formatKey(key)
v, ok := m.overlays.Get(realKey) v, ok := m.overlays.Get(realKey)
@ -210,6 +220,7 @@ func (m *Manager) AddSource(source Source) error {
return err return err
} }
source.SetManager(m)
m.sources.Insert(sourceName, source) m.sources.Insert(sourceName, source)
err := m.pullSourceConfigs(sourceName) err := m.pullSourceConfigs(sourceName)

View File

@ -270,6 +270,9 @@ func (ErrSource) GetPriority() int {
return 2 return 2
} }
func (ErrSource) SetManager(m ConfigManager) {
}
// GetSourceName implements Source // GetSourceName implements Source
func (ErrSource) GetSourceName() string { func (ErrSource) GetSourceName() string {
return "ErrSource" return "ErrSource"

View File

@ -23,12 +23,17 @@ const (
LowPriority = NormalPriority + 10 LowPriority = NormalPriority + 10
) )
type ConfigManager interface {
EvictCacheValueByFormat(keys ...string)
}
type Source interface { type Source interface {
GetConfigurations() (map[string]string, error) GetConfigurations() (map[string]string, error)
GetConfigurationByKey(string) (string, error) GetConfigurationByKey(string) (string, error)
GetPriority() int GetPriority() int
GetSourceName() string GetSourceName() string
SetEventHandler(eh EventHandler) SetEventHandler(eh EventHandler)
SetManager(m ConfigManager)
UpdateOptions(opt Options) UpdateOptions(opt Options)
Close() Close()
} }