parser

package
v4.0.0+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 1, 2019 License: Apache-2.0 Imports: 2 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config struct {
	// dataFormat specifies a data format to parse: `json`, `value`, `influx`, `graphite`, `value`, `nagios`,
	// `collectd`, `dropwizard`, `wavefront`, `grok`, `csv`, or `logfmt`.
	DataFormat string `yaml:"dataFormat" default:"influx"`

	// defaultTags are tags that will be added to all metrics. (`json`, `value`, `graphite`, `collectd`, `dropwizard`,
	// `wavefront`, `grok`, `csv` and `logfmt` only)
	DefaultTags map[string]string `yaml:"defaultTags"`

	// metricName applies to (`json` and `value`). This will be the name of the measurement.
	MetricName string `yaml:"metricName"`

	// dataType specifies the value type to parse the value to: `integer`, `float`,
	// `long`, `string`, or `boolean`. (`value` only)
	DataType string `yaml:"dataType"`

	// A list of tag names to fetch from JSON data. (`json` only)
	TagKeys []string `yaml:"JSONTagKeys"`
	// A list of fields in JSON to extract and use as string fields. (json only)
	JSONStringFields []string `yaml:"JSONStringFields"`
	// A path used to extract the metric name in JSON data.  (`json` only)
	JSONNameKey string `yaml:"JSONNameKey"`
	// A gjson path for json parser. (`json` only)
	JSONQuery string `yaml:"JSONQuery"`
	// The name of the timestamp key. (`json` only)
	JSONTimeKey string `yaml:"JSONTimeKey"`
	// Specifies the timestamp format. (`json` only)
	JSONTimeFormat string `yaml:"JSONTimeFormat"`

	// Separator for Graphite data. (`graphite` only).
	Separator string `yaml:"separator"`
	// A list of templates for Graphite data. (`graphite` only).
	Templates []string `yaml:"templates"`

	// The path to the collectd authentication file (`collectd` only)
	CollectdAuthFile string `yaml:"collectdAuthFile"`
	// Specifies the security level: `none` (default), `sign`, or
	// `encrypt`. (`collectd only`)
	CollectdSecurityLevel string `yaml:"collectdSecurityLevel"`
	// A list of paths to collectd TypesDB files. (`collectd` only)
	CollectdTypesDB []string `yaml:"collectdTypesDB"`
	// Indicates whether to separate or join multivalue metrics. (`collectd` only)
	CollectdSplit string `yaml:"collectdSplit"`

	// An optional gjson path used to locate a metric registry inside of JSON data.
	// The default behavior is to consider the entire JSON document. (`dropwizard` only)
	DropwizardMetricRegistryPath string `yaml:"dropwizardMetricRegistryPath"`
	// An optional gjson path used to identify the drop wizard metric timestamp. (`dropwizard` only)
	DropwizardTimePath string `yaml:"dropwizardTimePath"`
	// The format used for parsing the drop wizard metric timestamp.
	// The default format is time.RFC3339. (`dropwizard` only)
	DropwizardTimeFormat string `yaml:"dropwizardTimeFormat"`
	// An optional gjson path used to locate drop wizard tags. (`dropwizard` only)
	DropwizardTagsPath string `yaml:"dropwizardTagsPath"`
	// A map of gjson tag names and gjson paths used to extract tag values from the JSON document.
	// This is only used if `dropwizardTagsPath` is not specified. (`dropwizard` only)
	DropwizardTagPathsMap map[string]string `yaml:"dropwizardTagPathsMap"`

	// A list of patterns to match. (`grok` only)
	GrokPatterns []string `yaml:"grokPatterns"`
	// A list of named grok patterns to match.  (`grok` only)
	GrokNamedPatterns []string `yaml:"grokNamedPatterns"`
	// Custom grok patterns. (`grok` only)
	GrokCustomPatterns string `yaml:"grokCustomPatterns"`
	// List of paths to custom grok pattern files. (`grok` only)
	GrokCustomPatternFiles []string `yaml:"grokCustomPatternFiles"`
	// Specifies the timezone.  The default is UTC time.  Other options are `Local` for the
	// local time on the machine, `UTC`, and `Canada/Eastern` (unix style timezones).  (`grok` only)
	GrokTimeZone string `yaml:"grokTimezone"`

	// The delimiter used between fields in the csv. (`csv` only)
	CSVDelimiter string `yaml:"CSVDelimiter"`
	// The character used to mark rows as comments. (`csv` only)
	CSVComment string `yaml:"CSVComment"`
	// Indicates whether to trim leading white from fields. (`csv` only)
	CSVTrimSpace bool `yaml:"CSVTrimSpace"`
	// List of custom column names.  All columns must have names.  Unnamed columns are ignored.
	// This configuration must be set when `CSVHeaderRowCount` is 0. (`csv` only)
	CSVColumnNames []string `yaml:"CSVColumnNames"`
	// List of columns that should be added as tags.  Unspecified columns will be added as fields. (`csv` only)
	CSVTagColumns []string `yaml:"CSVTagColumns"`
	//  The name of the column to extract the metric name from (`csv` only)
	CSVMeasurementColumn string `yaml:"CSVMeasurementColumn"`
	// The name of the column to extract the metric timestamp from.
	// `CSVTimestampFormat` must be set when using this option.  (`csv` only)
	CSVTimestampColumn string `yaml:"CSVTimestampColumn"`
	//  The format to use for extracting timestamps. (`csv` only)
	CSVTimestampFormat string `yaml:"CSVTimestampFormat"`
	// The number of rows that are headers.  By default no rows are treated as headers.  (`csv` only)
	CSVHeaderRowCount int `yaml:"CSVHeaderRowCount"`
	// The number of rows to ignore before looking for headers. (`csv` only)
	CSVSkipRows int `yaml:"CSVSkipRows"`
	// The number of columns to ignore before parsing data on a given row. (`csv` only)
	CSVSkipColumns int `yaml:"CSVSkipColumns"`
}

Config implements Telegraf parsers.Config, but with SignalFx Smart Agent struct tags and a methods for returning a Telegraf parsers.Config struct and a Telegraf parsers.Parser. Please refer to Telegraf's (documentation)[https://github.com/influxdata/telegraf/blob/master/docs/DATA_FORMATS_INPUT.md#influx] for more information about the different parsers and their specific configurations

func (*Config) GetTelegrafConfig

func (c *Config) GetTelegrafConfig() (config *parsers.Config, err error)

GetTelegrafConfig returns the configuration as a Telegraf *parsers.Config

func (*Config) GetTelegrafParser

func (c *Config) GetTelegrafParser() (parser parsers.Parser, err error)

GetTelegrafParser returns a pointer to a telegraf *parsers.Parser

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL