New announcements for Serverless, Network, RUM, and more from Dash! New announcements from Dash!

Datagram Format and Shell Usage

This section specifies the raw datagram format for each data type that DogStatsD accepts. This isn’t required reading if you’re using any of the DogStatsD client libraries; however, if you want to write your own library, or use the shell to send metrics or events, then read on.

Datagram Format



<METRIC_NAME>Yesa string with no colons, bars, or @ characters. See the metric naming policy.
<VALUE>Yesan integer or float.
<TYPE>Yesc for counter, g for gauge, ms for timer, h for histogram, s for set.
<SAMPLE_RATE>Noa float between 0 and 1, inclusive. Only works with counter, histogram, and timer metrics. Default is 1 (i.e. sample 100% of the time).
<TAG_KEY_1>:<TAG_VALUE_1>,<TAG_2>Noa comma separated list of tags. Use colons for key/value tags, i.e. env:prod. The key device is reserved; Datadog drops a user-added tag like device:foobar.

Here are some example datagrams:

## Increment the page.views counter

## Record the fuel tank is half-empty

## Sample the song length histogram half of the time

## Track a unique visitor to the site

## Increment the active users counter, tag by country of origin|c|#country:china

## Track active China users and use a sample rate|c|@0.5|#country:china



_eYesThe datagram must begin with _e
<TITLE>YesEvent title.
<TEXT>YesEvent text. Insert line breaks with an escaped slash (\\n)
d:<TIMESTAMP>NoAdd a timestamp to the event. Default is the current Unix epoch timestamp.
h:<HOSTNAME>NoAdd a hostname to the event. No default.
k:aggregation_keyNoAdd an aggregation key to group the event with others that have the same key. No default.
p:<PRIORITY>NoSet to ‘normal’ or ‘low’. Default ‘normal’.
s:source_type_nameNoAdd a source type to the event. No default.
t:<ALERT_TYPE>NoSet to ‘error’, ‘warning’, ‘info’ or ‘success’. Default ‘info’.
#<TAG_KEY_1>:<TAG_VALUE_1>,<TAG_2>NoThe colon in tags is part of the tag list string and has no parsing purpose like for the other parameters. No default.

Here are some example datagrams:

## Send an exception
_e{21,36}:An exception occurred|Cannot parse CSV file from|t:warning|#err_type:bad_file

## Send an event with a newline in the text
_e{21,42}:An exception occurred|Cannot parse JSON request:\\n{"foo: "bar"}|p:low|#err_type:bad_request

Service Checks


_scYesthe datagram must begin with _sc
<NAME>YesService check name.
<STATUS>YesInteger corresponding to the check status (OK = 0, WARNING = 1, CRITICAL = 2, UNKNOWN = 3).
d:<TIMESTAMP>NoAdd a timestamp to the check. Default is the current Unix epoch timestamp.
h:<HOSTNAME>NoAdd a hostname to the event. No default.
#<TAG_KEY_1>:<TAG_VALUE_1>,<TAG_2>NoThe colon in tags is part of the tag list string and has no parsing purpose like for the other parameters. No default.
m:<SERVICE_CHECK_MESSAGE>NoAdd a message describing the current state of the service check. This field MUST be positioned last among the metadata fields. No default.

Here’s an example datagram:

# Send a CRITICAL status for a remote connection
_sc|Redis connection|2|#redis_instance:|m:Redis connection timed out after 10s

Send metrics and events using DogStatsD and the shell

For Linux and other Unix-like OS, use Bash. For Windows, you need Powershell and powershell-statsd (a simple Powershell function that takes care of the network bits).

The idea behind DogStatsD is: create a message that contains information about your metric/event, and send it to a collector over UDP on port 8125. Read more about the message format.

Sending metrics

The format for sending metrics is <METRIC_NAME>:<VALUE>|<TYPE>|@<SAMPLE_RATE>|#<TAG_KEY_1>:<TAG_VALUE_1>,<TAG_2>, to send datapoints for a gauge metric called custom_metric with the shell tag. Using a locally installed Agent as a collector, the destination IP address is

Linux options:

vagrant@vagrant-ubuntu-14-04:~$ echo -n "custom_metric:60|g|#shell" >/dev/udp/localhost/8125
vagrant@vagrant-ubuntu-14-04:~$ echo -n "custom_metric:60|g|#shell" | nc -4u -w0 8125
vagrant@vagrant-ubuntu-14-04:~$ echo -n "|c"|nc -4u -w1 localhost 8125

Windows options:

PS C:\vagrant> .\send-statsd.ps1 "custom_metric:123|g|#shell"
PS C:\vagrant>

On any platform with Python (on Windows, the Agent’s embedded Python interpreter can be used, which is located at C:\Program Files\Datadog\Datadog Agent\embedded\python.exe for Agent versions <= 6.11 and in C:\Program Files\Datadog\Datadog Agent\embedded<PYTHON_MAJOR_VERSION>\python.exe for Agent versions >= 6.12):

import socket
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # UDP
sock.sendto("custom_metric:60|g|#shell", ("localhost", 8125))

To send metrics on containerized environments, refer to the DogStatsD on Kubernetes documentation, in conjunction with the instructions for configuring APM on Kubernetes using DaemonSets or Helm, depending on your installation. The Docker APM documentation may also be helpful.

Sending events

The format for sending events is:


Here, calculate the size of the event’s title and body:

On Linux:

vagrant@vagrant-ubuntu-14-04:~$ title="Event from the shell"
vagrant@vagrant-ubuntu-14-04:~$ text="This was sent from Bash!"
vagrant@vagrant-ubuntu-14-04:~$ echo "_e{${#title},${#text}}:$title|$text|#shell,bash"  >/dev/udp/localhost/8125

On Windows:

PS C:\vagrant> $title = "Event from the shell"
PS C:\vagrant> $text = "This was sent from Powershell!"
PS C:\vagrant> .\send-statsd.ps1 "_e{$($title.length),$($text.Length)}:$title|$text|#shell,powershell"

Further reading