-
Notifications
You must be signed in to change notification settings - Fork 3.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor(bloom planner): Compute gaps and build tasks from metas and …
…TSDBs (#12994)
- Loading branch information
1 parent
7a3338e
commit 3195036
Showing
14 changed files
with
1,568 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,21 +1,40 @@ | ||
package planner | ||
|
||
import "flag" | ||
import ( | ||
"flag" | ||
"fmt" | ||
"time" | ||
) | ||
|
||
// Config configures the bloom-planner component. | ||
type Config struct { | ||
// TODO: Add config | ||
PlanningInterval time.Duration `yaml:"planning_interval"` | ||
MinTableOffset int `yaml:"min_table_offset"` | ||
MaxTableOffset int `yaml:"max_table_offset"` | ||
} | ||
|
||
// RegisterFlagsWithPrefix registers flags for the bloom-planner configuration. | ||
func (cfg *Config) RegisterFlagsWithPrefix(_ string, _ *flag.FlagSet) { | ||
// TODO: Register flags with flagsPrefix | ||
func (cfg *Config) RegisterFlagsWithPrefix(prefix string, f *flag.FlagSet) { | ||
f.DurationVar(&cfg.PlanningInterval, prefix+".interval", 8*time.Hour, "Interval at which to re-run the bloom creation planning.") | ||
f.IntVar(&cfg.MinTableOffset, prefix+".min-table-offset", 1, "Newest day-table offset (from today, inclusive) to build blooms for. Increase to lower cost by not re-writing data to object storage too frequently since recent data changes more often at the cost of not having blooms available as quickly.") | ||
// TODO(owen-d): ideally we'd set this per tenant based on their `reject_old_samples_max_age` setting, | ||
// but due to how we need to discover tenants, we can't do that yet. Tenant+Period discovery is done by | ||
// iterating the table periods in object storage and looking for tenants within that period. | ||
// In order to have this done dynamically, we'd need to account for tenant specific overrides, which are also | ||
// dynamically reloaded. | ||
// I'm doing it the simple way for now. | ||
f.IntVar(&cfg.MaxTableOffset, prefix+".max-table-offset", 2, "Oldest day-table offset (from today, inclusive) to compact. This can be used to lower cost by not trying to compact older data which doesn't change. This can be optimized by aligning it with the maximum `reject_old_samples_max_age` setting of any tenant.") | ||
} | ||
|
||
func (cfg *Config) Validate() error { | ||
if cfg.MinTableOffset > cfg.MaxTableOffset { | ||
return fmt.Errorf("min-table-offset (%d) must be less than or equal to max-table-offset (%d)", cfg.MinTableOffset, cfg.MaxTableOffset) | ||
} | ||
|
||
return nil | ||
} | ||
|
||
type Limits interface { | ||
// TODO: Add limits | ||
BloomCreationEnabled(tenantID string) bool | ||
BloomSplitSeriesKeyspaceBy(tenantID string) int | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.