mirror of
https://github.com/ClusterCockpit/cc-metric-collector.git
synced 2024-12-26 15:29:04 +01:00
Reuse parser to avoid overhead in NATS receiver
This commit is contained in:
parent
4688997071
commit
f74d5dc51a
@ -11,7 +11,9 @@ import (
|
|||||||
|
|
||||||
type NatsReceiver struct {
|
type NatsReceiver struct {
|
||||||
Receiver
|
Receiver
|
||||||
nc *nats.Conn
|
nc *nats.Conn
|
||||||
|
handler *lp.MetricHandler
|
||||||
|
parser *lp.Parser
|
||||||
}
|
}
|
||||||
|
|
||||||
var DefaultTime = func() time.Time {
|
var DefaultTime = func() time.Time {
|
||||||
@ -42,6 +44,9 @@ func (r *NatsReceiver) Init(config ReceiverConfig, sink s.SinkFuncs) error {
|
|||||||
log.Print(err)
|
log.Print(err)
|
||||||
r.nc = nil
|
r.nc = nil
|
||||||
}
|
}
|
||||||
|
r.handler = lp.NewMetricHandler()
|
||||||
|
r.parser = lp.NewParser(r.handler)
|
||||||
|
r.parser.SetTimeFunc(DefaultTime)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,10 +56,7 @@ func (r *NatsReceiver) Start() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (r *NatsReceiver) _NatsReceive(m *nats.Msg) {
|
func (r *NatsReceiver) _NatsReceive(m *nats.Msg) {
|
||||||
handler := lp.NewMetricHandler()
|
metrics, err := r.parser.Parse(m.Data)
|
||||||
parser := lp.NewParser(handler)
|
|
||||||
parser.SetTimeFunc(DefaultTime)
|
|
||||||
metrics, err := parser.Parse(m.Data)
|
|
||||||
if err == nil {
|
if err == nil {
|
||||||
for _, m := range metrics {
|
for _, m := range metrics {
|
||||||
y, err := lp.New(m.Name(), Tags2Map(m), Fields2Map(m), m.Time())
|
y, err := lp.New(m.Name(), Tags2Map(m), Fields2Map(m), m.Time())
|
||||||
|
Loading…
Reference in New Issue
Block a user