The statsd plugin is a special type of plugin which runs a backgrounded statsd listener service while agent is running.
The format of the statsd messages was based on the format described in the original etsy statsd implementation. In short, the agent statsd listener will accept:
deploys.test.myservice:1|c<- increments by 1
deploys.test.myservice:101|c<- increments by 101
deploys.test.myservice:email@example.com<- with sample rate, increments by 10
users.unique:102|s<- would result in a count of 2 for
Timings & Histograms
load.time:firstname.lastname@example.org<- sampled 1/10 of the time
It is possible to omit repetitive names and merge individual stats into a single line by separating them with additional colons:
This also allows for mixed types in a single line:
foo:1|c:200|ms is internally split into two individual metrics
foo:200|ms which are added to the aggregator separately.
# Statsd Server [[inputs.statsd]] ## Instance ID -- required instance_id = "" ## Protocol, must be "tcp", "udp4", "udp6" or "udp" (default=udp) protocol = "udp" ## MaxTCPConnection - applicable when protocol is set to tcp (default=250) max_tcp_connections = 250 ## Enable TCP keep alive probes (default=false) tcp_keep_alive = false ## Specifies the keep-alive period for an active network connection. ## Only applies to TCP sockets and will be ignored if tcp_keep_alive is false. ## Defaults to the OS configuration. # tcp_keep_alive_period = "2h" ## Address and port to host UDP listener on service_address = ":8125" ## separator to use between elements of a statsd metric metric_separator = "_" ## Parses extensions to statsd in the datadog statsd format ## currently supports metrics and datadog tags. ## http://docs.datadoghq.com/guides/dogstatsd/ datadog_extensions = true ## Statsd data translation templates, more info can be read here: ## https://github.com/circonus-labs/circonus-unified-agent/blob/master/docs/TEMPLATE_PATTERN.md # templates = [ # "cpu.* measurement*" # ] ## Number of UDP messages allowed to queue up, once filled, ## the statsd server will start dropping packets allowed_pending_messages = 10000 ## Maximum socket buffer size in bytes, once the buffer fills up, metrics ## will start dropping. Defaults to the OS default. # read_buffer_size = 65535
protocol string: Protocol used in listener - tcp or udp options
max_tcp_connections int: Maximum number of concurrent TCP connections to allow. Used when protocol is set to tcp.
tcp_keep_alive boolean: Enable TCP keep alive probes
tcp_keep_alive_period internal.Duration: Specifies the keep-alive period for an active network connection
service_address string: Address to listen for statsd UDP packets on
- allowed_pending_messages integer: Number of messages allowed to queue up waiting to be processed. When this fills, messages will be dropped and logged.
templates string: Templates for transforming statsd buckets into influx measurements and tags.
datadog_extensions boolean: Enable parsing of DataDog’s extensions to dogstatsd format Note: events are ignored at this time.
Templates for Statsd bucket –> measurement name and tags
The plugin supports specifying templates for transforming statsd buckets into measurement names and tags. The templates have a measurement keyword, which can be used to specify parts of the bucket that are to be used in the measurement name. Other words in the template are used as tag names. For example, the following template:
templates = [ "measurement.measurement.region" ]
would result in the following transformation:
cpu.load.us-west:100|g => cpu_load,region=us-west 100
Users can also filter the template to use based on the name of the bucket, using glob matching, like so:
templates = [ "cpu.* measurement.measurement.region", "mem.* measurement.measurement.host" ]
which would result in the following transformation:
cpu.load.us-west:100|g => cpu_load,region=us-west 100 mem.cached.localhost:256|g => mem_cached,host=localhost 256
Consult the Template Patterns documentation for additional details.