2020-06-05 07:09:22 +08:00
|
|
|
package shim
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"sync"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/influxdata/telegraf"
|
|
|
|
|
"github.com/influxdata/telegraf/agent"
|
2021-04-14 05:13:46 +08:00
|
|
|
"github.com/influxdata/telegraf/plugins/parsers/influx"
|
2020-06-05 07:09:22 +08:00
|
|
|
"github.com/influxdata/telegraf/plugins/processors"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// AddProcessor adds the processor to the shim. Later calls to Run() will run this.
|
|
|
|
|
func (s *Shim) AddProcessor(processor telegraf.Processor) error {
|
2020-08-29 06:45:38 +08:00
|
|
|
setLoggerOnPlugin(processor, s.Log())
|
2020-06-05 07:09:22 +08:00
|
|
|
p := processors.NewStreamingProcessorFromProcessor(processor)
|
|
|
|
|
return s.AddStreamingProcessor(p)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// AddStreamingProcessor adds the processor to the shim. Later calls to Run() will run this.
|
|
|
|
|
func (s *Shim) AddStreamingProcessor(processor telegraf.StreamingProcessor) error {
|
2020-08-29 06:45:38 +08:00
|
|
|
setLoggerOnPlugin(processor, s.Log())
|
2020-06-05 07:09:22 +08:00
|
|
|
if p, ok := processor.(telegraf.Initializer); ok {
|
|
|
|
|
err := p.Init()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("failed to init input: %s", err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
s.Processor = processor
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (s *Shim) RunProcessor() error {
|
|
|
|
|
acc := agent.NewAccumulator(s, s.metricCh)
|
|
|
|
|
acc.SetPrecision(time.Nanosecond)
|
|
|
|
|
|
2021-04-14 05:13:46 +08:00
|
|
|
err := s.Processor.Start(acc)
|
2020-06-05 07:09:22 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("failed to start processor: %w", err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
wg := sync.WaitGroup{}
|
|
|
|
|
wg.Add(1)
|
|
|
|
|
go func() {
|
|
|
|
|
s.writeProcessedMetrics()
|
|
|
|
|
wg.Done()
|
|
|
|
|
}()
|
|
|
|
|
|
2021-04-14 05:13:46 +08:00
|
|
|
parser := influx.NewStreamParser(s.stdin)
|
|
|
|
|
for {
|
|
|
|
|
m, err := parser.Next()
|
2020-06-05 07:09:22 +08:00
|
|
|
if err != nil {
|
2021-04-14 05:13:46 +08:00
|
|
|
if err == influx.EOF {
|
|
|
|
|
break // stream ended
|
|
|
|
|
}
|
|
|
|
|
if parseErr, isParseError := err.(*influx.ParseError); isParseError {
|
|
|
|
|
fmt.Fprintf(s.stderr, "Failed to parse metric: %s\b", parseErr)
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
fmt.Fprintf(s.stderr, "Failure during reading stdin: %s\b", err)
|
2020-06-05 07:09:22 +08:00
|
|
|
continue
|
|
|
|
|
}
|
2021-04-14 05:13:46 +08:00
|
|
|
|
2020-06-05 07:09:22 +08:00
|
|
|
s.Processor.Add(m, acc)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
close(s.metricCh)
|
|
|
|
|
s.Processor.Stop()
|
|
|
|
|
wg.Wait()
|
|
|
|
|
return nil
|
|
|
|
|
}
|