mirror of
https://github.com/openziti/zrok.git
synced 2025-08-19 04:06:18 +02:00
wire in the new 'limits.Agent' infrastructure; extend the 'metrics.Agent' to support additional 'metrics.UsageSink' instances (#271)
This commit is contained in:
committed by
Kenneth Bingham
parent
e824c87d08
commit
29f38de546
@@ -11,7 +11,7 @@ type Agent struct {
|
||||
src ZitiEventJsonSource
|
||||
srcJoin chan struct{}
|
||||
cache *cache
|
||||
snk UsageSink
|
||||
snks []UsageSink
|
||||
}
|
||||
|
||||
func NewAgent(cfg *AgentConfig, str *store.Store, ifxCfg *InfluxConfig) (*Agent, error) {
|
||||
@@ -22,10 +22,14 @@ func NewAgent(cfg *AgentConfig, str *store.Store, ifxCfg *InfluxConfig) (*Agent,
|
||||
return nil, errors.New("invalid event json source")
|
||||
}
|
||||
a.cache = newShareCache(str)
|
||||
a.snk = newInfluxWriter(ifxCfg)
|
||||
a.snks = append(a.snks, newInfluxWriter(ifxCfg))
|
||||
return a, nil
|
||||
}
|
||||
|
||||
func (a *Agent) AddUsageSink(snk UsageSink) {
|
||||
a.snks = append(a.snks, snk)
|
||||
}
|
||||
|
||||
func (a *Agent) Start() error {
|
||||
a.events = make(chan ZitiEventJson)
|
||||
srcJoin, err := a.src.Start(a.events)
|
||||
@@ -44,8 +48,10 @@ func (a *Agent) Start() error {
|
||||
if err := a.cache.addZrokDetail(usage); err != nil {
|
||||
logrus.Error(err)
|
||||
}
|
||||
if err := a.snk.Handle(usage); err != nil {
|
||||
logrus.Error(err)
|
||||
for _, snk := range a.snks {
|
||||
if err := snk.Handle(usage); err != nil {
|
||||
logrus.Error(err)
|
||||
}
|
||||
}
|
||||
} else {
|
||||
logrus.Error(err)
|
||||
|
Reference in New Issue
Block a user