1 unstable release
0.1.0 | Jul 25, 2024 |
---|
#582 in Parser implementations
33KB
836 lines
MetCo
Metrics Collector inspired by StatsD.
Additional/removed features compared to StatsD are:
- support for additional time units like
seconds
,microseconds
andnanoseconds
, - gauge removal,
- setting gauge to negative value without first setting it to zero,
- sets are not supported and
- no sampling interval.
Disclaimer
I'm still learning Rust, and although I run this in production for two of my clients without any issue, I can not advise you to do the same until you've checked my source code. I believe it's quite stable, buy me being a professional I can not guarantee that this could not cause some issue for you.
That being said, I'm looking forward to more experienced Rust developers suggesting improvements and helping me to get better in Rust.
Also, I do plan to keep this as simple as possible because I like Linux philosophy "Do one thing and do it well".
Protocol
Protocol is simple text based protocol. Metrics are in form of name|type|value
and optionally some additional fields separated by |
depending on metric type.
Metric name is any valid UTF-8 sequence of at least one byte. It's backends job to sanitize name if needed. Pipe character and backslash can be escaped using backslash.
Type can be any of c
, t
or g
.
Value format and optional additional fields are defined by the metric type.
Multiple metrics can be sent separated by \n
. Data parsed before a parsing error occurs is still considered valid, but remaining data is not parsed.
Counters
Value is always a positive natural number.
abc|c|1234
Timers
By default resolution is milliseconds.
Value is always a positive natural number
abc|t|1234
Supported resolutions are s
, ms
, us
and ns
.
abc|t|1234|ms
Gauges
Value is a natural number.
abc|g|123
abc|g|-123
Instead of setting value, it can be updated by incrementing/decrementing by a specified amount.
abc|g|+=123
abc|g|-=123
Gauge can be removed by sending x
as a value.
abc|g|x
Dependencies
~11–20MB
~299K SLoC