Arbitrary rule & group loading (#7569)

* allows loading rule groups via an interface

Signed-off-by: Owen Diehl <ow.diehl@gmail.com>
This commit is contained in:
Owen Diehl 2020-07-22 10:19:34 -04:00 committed by GitHub
parent a0df8a383a
commit 9ccedc0407
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -852,6 +852,7 @@ type ManagerOptions struct {
OutageTolerance time.Duration OutageTolerance time.Duration
ForGracePeriod time.Duration ForGracePeriod time.Duration
ResendDelay time.Duration ResendDelay time.Duration
GroupLoader GroupLoader
Metrics *Metrics Metrics *Metrics
} }
@ -863,6 +864,10 @@ func NewManager(o *ManagerOptions) *Manager {
o.Metrics = NewGroupMetrics(o.Registerer) o.Metrics = NewGroupMetrics(o.Registerer)
} }
if o.GroupLoader == nil {
o.GroupLoader = FileLoader{}
}
m := &Manager{ m := &Manager{
groups: map[string]*Group{}, groups: map[string]*Group{},
opts: o, opts: o,
@ -974,6 +979,22 @@ func (m *Manager) Update(interval time.Duration, files []string, externalLabels
return nil return nil
} }
// GroupLoader is responsible for loading rule groups from arbitrary sources and parsing them.
type GroupLoader interface {
Load(identifier string) (*rulefmt.RuleGroups, []error)
Parse(query string) (parser.Expr, error)
}
// FileLoader is the default GroupLoader implementation. It defers to rulefmt.ParseFile
// and parser.ParseExpr
type FileLoader struct{}
func (FileLoader) Load(identifier string) (*rulefmt.RuleGroups, []error) {
return rulefmt.ParseFile(identifier)
}
func (FileLoader) Parse(query string) (parser.Expr, error) { return parser.ParseExpr(query) }
// LoadGroups reads groups from a list of files. // LoadGroups reads groups from a list of files.
func (m *Manager) LoadGroups( func (m *Manager) LoadGroups(
interval time.Duration, externalLabels labels.Labels, filenames ...string, interval time.Duration, externalLabels labels.Labels, filenames ...string,
@ -983,7 +1004,7 @@ func (m *Manager) LoadGroups(
shouldRestore := !m.restored shouldRestore := !m.restored
for _, fn := range filenames { for _, fn := range filenames {
rgs, errs := rulefmt.ParseFile(fn) rgs, errs := m.opts.GroupLoader.Load(fn)
if errs != nil { if errs != nil {
return nil, errs return nil, errs
} }
@ -996,7 +1017,7 @@ func (m *Manager) LoadGroups(
rules := make([]Rule, 0, len(rg.Rules)) rules := make([]Rule, 0, len(rg.Rules))
for _, r := range rg.Rules { for _, r := range rg.Rules {
expr, err := parser.ParseExpr(r.Expr.Value) expr, err := m.opts.GroupLoader.Parse(r.Expr.Value)
if err != nil { if err != nil {
return nil, []error{errors.Wrap(err, fn)} return nil, []error{errors.Wrap(err, fn)}
} }