node: Allow tombstone_lifetime config to be loaded on the fly #1405

Merged
fyrchik merged 1 commit from elebedeva/frostfs-node:feat/tombstone-reload-config into master 2024-10-02 07:27:08 +00:00
2 changed files with 17 additions and 6 deletions

View file

@ -105,6 +105,10 @@ type applicationConfiguration struct {
timestamp bool
}
ObjectCfg struct {
tombstoneLifetime uint64

We have this uint64 and atomic in some other place.
Could you describe why can't we have a single atomic?

We have this `uint64` and atomic in some other place. Could you describe why can't we have a single atomic?

I wanted to maintain the style of readConfig() and reloadConfig() where parameters firstly stored in applicationConfiguration and then are reloaded.

I wanted to maintain the style of [readConfig()](https://git.frostfs.info/TrueCloudLab/frostfs-node/src/commit/51b9a31ee3c878a8aea440a69bf39a06545192ea/cmd/frostfs-node/config.go#L203) and [reloadConfig()](https://git.frostfs.info/TrueCloudLab/frostfs-node/src/commit/51b9a31ee3c878a8aea440a69bf39a06545192ea/cmd/frostfs-node/config.go#L1281) where parameters firstly stored in `applicationConfiguration` and then are reloaded.
}
EngineCfg struct {
errorThreshold uint32
shardPoolSize uint32
@ -223,6 +227,10 @@ func (a *applicationConfiguration) readConfig(c *config.Config) error {
a.LoggerCfg.destination = loggerconfig.Destination(c)
a.LoggerCfg.timestamp = loggerconfig.Timestamp(c)
// Object
a.ObjectCfg.tombstoneLifetime = objectconfig.TombstoneLifetime(c)
// Storage Engine
a.EngineCfg.errorThreshold = engineconfig.ShardErrorThreshold(c)
@ -624,7 +632,7 @@ type cfgObject struct {
cfgLocalStorage cfgLocalStorage
tombstoneLifetime uint64
tombstoneLifetime *atomic.Uint64
skipSessionTokenIssuerVerification bool
}
@ -815,9 +823,11 @@ func initCfgGRPC() cfgGRPC {
}
func initCfgObject(appCfg *config.Config) cfgObject {
var tsLifetime atomic.Uint64
tsLifetime.Store(objectconfig.TombstoneLifetime(appCfg))
return cfgObject{
pool: initObjectPool(appCfg),
tombstoneLifetime: objectconfig.TombstoneLifetime(appCfg),
tombstoneLifetime: &tsLifetime,
skipSessionTokenIssuerVerification: objectconfig.Put(appCfg).SkipSessionTokenIssuerVerification(),
}
}
@ -1296,6 +1306,9 @@ func (c *cfg) reloadConfig(ctx context.Context) {
components := c.getComponents(ctx, logPrm)
// Object
c.cfgObject.tombstoneLifetime.Store(c.ObjectCfg.tombstoneLifetime)
// Storage Engine
var rcfg engine.ReConfiguration

View file

@ -109,13 +109,12 @@ func (s *objectSvc) GetRangeHash(ctx context.Context, req *object.GetRangeHashRe
type delNetInfo struct {
netmap.State
tsLifetime uint64
cfg *cfg
}
func (i *delNetInfo) TombstoneLifetime() (uint64, error) {
return i.tsLifetime, nil
return i.cfg.cfgObject.tombstoneLifetime.Load(), nil
}
// returns node owner ID calculated from configured private key.
@ -425,7 +424,6 @@ func createDeleteService(c *cfg, keyStorage *util.KeyStorage, sGet *getsvc.Servi
sPut,
&delNetInfo{
State: c.cfgNetmap.state,
tsLifetime: c.cfgObject.tombstoneLifetime,
cfg: c,
},