Documentation ¶
Index ¶
- Variables
- func ValidMetric(sample UDPMetric) bool
- func ValidTrace(sample *ssf.SSFSpan) bool
- type Aggregate
- type Counter
- type Gauge
- type Histo
- type HistogramAggregates
- type InterMetric
- type InvalidMetrics
- type InvalidTrace
- type JSONMetric
- type Message
- type MetricKey
- type MetricScope
- type MetricType
- type Set
- type SplitBytes
- type UDPEvent
- type UDPMetric
- type UDPServiceCheck
Constants ¶
This section is empty.
Variables ¶
var AggregatesLookup = map[string]Aggregate{ "min": AggregateMin, "max": AggregateMax, "median": AggregateMedian, "avg": AggregateAverage, "count": AggregateCount, "sum": AggregateSum, "hmean": AggregateHarmonicMean, }
Functions ¶
func ValidMetric ¶ added in v1.5.2
ValidMetric takes in an SSF sample and determines if it is valid or not.
func ValidTrace ¶ added in v1.5.2
ValidTrace takes in an SSF span and determines if it is valid or not. It also makes sure the Tags is non-nil, since we use it later.
Types ¶
type Counter ¶
Counter is an accumulator
func NewCounter ¶
NewCounter generates and returns a new Counter.
func (*Counter) Combine ¶
Combine merges the values seen with another set (marshalled as a byte slice)
func (*Counter) Export ¶
func (c *Counter) Export() (JSONMetric, error)
Export converts a Counter into a JSONMetric which reports the rate.
type Gauge ¶
Gauge retains whatever the last value was.
func (*Gauge) Flush ¶
func (g *Gauge) Flush() []InterMetric
Flush generates an InterMetric from the current state of this gauge.
type Histo ¶
type Histo struct { Name string Tags []string Value *tdigest.MergingDigest // these values are computed from only the samples that came through this // veneur instance, ignoring any histograms merged from elsewhere // we separate them because they're easy to aggregate on the backend without // loss of granularity, and having host-local information on them might be // useful LocalWeight float64 LocalMin float64 LocalMax float64 LocalSum float64 LocalReciprocalSum float64 }
Histo is a collection of values that generates max, min, count, and percentiles over time.
func (*Histo) Combine ¶
Combine merges the values of a histogram with another histogram (marshalled as a byte slice)
func (*Histo) Export ¶
func (h *Histo) Export() (JSONMetric, error)
Export converts a Histogram into a JSONMetric
func (*Histo) Flush ¶
func (h *Histo) Flush(interval time.Duration, percentiles []float64, aggregates HistogramAggregates) []InterMetric
Flush generates InterMetrics for the current state of the Histo. percentiles indicates what percentiles should be exported from the histogram.
type HistogramAggregates ¶
type InterMetric ¶ added in v1.7.0
type InterMetric struct { Name string Timestamp int64 Value float64 Tags []string Type MetricType }
InterMetric represents a metric that has been completed and is ready for flushing by sinks.
type InvalidMetrics ¶ added in v1.7.0
type InvalidMetrics interface { error // Samples returns any samples that couldn't be parsed or validated. Samples() []*ssf.SSFSample }
InvalidMetrics is an error type returned if any metric could not be parsed.
type InvalidTrace ¶ added in v1.7.0
type InvalidTrace struct {
// contains filtered or unexported fields
}
InvalidTrace is an error type indicating that an SSF span was invalid.
func (*InvalidTrace) Error ¶ added in v1.7.0
func (e *InvalidTrace) Error() string
type JSONMetric ¶
type JSONMetric struct { MetricKey Tags []string `json:"tags"` // the Value is an internal representation of the metric's contents, eg a // gob-encoded histogram or hyperloglog. Value []byte `json:"value"` }
JSONMetric is used to represent a metric that can be remarshaled with its internal state intact. It is used to send metrics from one Veneur to another.
type Message ¶ added in v1.7.0
type Message struct {
// contains filtered or unexported fields
}
A Message struct represents a parsed SSF message. It encapsulates an ssf.SSFSpan object, which can contain a trace span and/or a set of metrics.
func ParseSSF ¶ added in v1.5.2
ParseSSF takes in a byte slice and returns: a normalized SSFSpan and an error if any errors in parsing the SSF packet occur.
func (*Message) Metrics ¶ added in v1.7.0
Metrics examines an SSF message, parses and returns a new array containing any metrics contained in the message. If any parse error occurs in processing any of the metrics, ExtractMetrics collects them into the error type InvalidMetrics and returns this error alongside any valid metrics that could be parsed.
func (*Message) TraceSpan ¶ added in v1.7.0
TraceSpan checks if an SSF message is a valid trace. If so, it returns a pointer to that original span. If the span is not a valid trace, TraceSpan returns nil and an *InvalidTrace error type.
The span returned from TraceSpan does contain the (unparsed) metric samples contained in the span. Note also that since the data returned is a pointer to the original span, it's not advisable to modify that span directly.
type MetricKey ¶
type MetricKey struct { Name string `json:"name"` Type string `json:"type"` JoinedTags string `json:"tagstring"` // tags in deterministic order, joined with commas }
MetricKey is a struct used to key the metrics into the worker's map. All fields must be comparable types.
type MetricScope ¶
type MetricScope int
const ( MixedScope MetricScope = iota LocalOnly GlobalOnly )
type MetricType ¶ added in v1.7.0
type MetricType int
MetricType defines what kind of metric this is, so that we or our upstream sinks can do the right thing with it.
const ( // CounterMetric is a counter CounterMetric MetricType = iota // GaugeMetric is a gauge GaugeMetric )
func (MetricType) String ¶ added in v1.7.0
func (i MetricType) String() string
type Set ¶
type Set struct { Name string Tags []string Hll *hyperloglog.Sketch }
Set is a list of unique values seen.
func (*Set) Export ¶
func (s *Set) Export() (JSONMetric, error)
Export converts a Set into a JSONMetric which reports the Tags in the set.
func (*Set) Flush ¶
func (s *Set) Flush() []InterMetric
Flush generates an InterMetric for the state of this Set.
type SplitBytes ¶
type SplitBytes struct {
// contains filtered or unexported fields
}
SplitBytes iterates over a byte buffer, returning chunks split by a given delimiter byte. It does not perform any allocations, and does not modify the buffer it is given. It is not safe for use by concurrent goroutines.
sb := NewSplitBytes(buf, '\n') for sb.Next() { fmt.Printf("%q\n", sb.Chunk()) }
The sequence of chunks returned by SplitBytes is equivalent to calling bytes.Split, except without allocating an intermediate slice.
func NewSplitBytes ¶
func NewSplitBytes(buf []byte, delim byte) *SplitBytes
NewSplitBytes initializes a SplitBytes struct with the provided buffer and delimiter.
func (*SplitBytes) Next ¶
func (sb *SplitBytes) Next() bool
Next advances SplitBytes to the next chunk, returning true if a new chunk actually exists and false otherwise.
type UDPEvent ¶
type UDPEvent struct { Title string `json:"msg_title"` Text string `json:"msg_text"` Timestamp int64 `json:"timestamp,omitempty"` // represented as a unix epoch Hostname string `json:"host,omitempty"` Aggregation string `json:"aggregation_key,omitempty"` Priority string `json:"priority,omitempty"` Source string `json:"source_type_name,omitempty"` AlertLevel string `json:"alert_type,omitempty"` Tags []string `json:"tags,omitempty"` }
UDPEvent represents the structure of datadog's undocumented /intake endpoint
func ParseEvent ¶
ParseEvent parses a packet that represents a UDPEvent.
type UDPMetric ¶
type UDPMetric struct { MetricKey Digest uint32 Value interface{} SampleRate float32 Tags []string Scope MetricScope }
UDPMetric is a representation of the sample provided by a client. The tag list should be deterministically ordered.
func ParseMetric ¶
ParseMetric converts the incoming packet from Datadog DogStatsD Datagram format in to a Metric. http://docs.datadoghq.com/guides/dogstatsd/#datagram-format
type UDPServiceCheck ¶
type UDPServiceCheck struct { Name string `json:"check"` Status int `json:"status"` Hostname string `json:"host_name"` Timestamp int64 `json:"timestamp,omitempty"` // represented as a unix epoch Tags []string `json:"tags,omitempty"` Message string `json:"message,omitempty"` }
UDPServiceCheck is a representation of the service check.
func ParseServiceCheck ¶
func ParseServiceCheck(packet []byte) (*UDPServiceCheck, error)
ParseServiceCheck parses a packet that represents a UDPServiceCheck.