- [CHANGE] Update exporter-toolkit & switch to slog (#586)
- [CHANGE] Update client_golang and prometheus-common
This is a breaking change for library users.
- [BUGFIX] Fix panic on certain invalid lines (#579)
- [FEATURE] Support dogstatsd extended aggregation (#558)
- [SECURITY] Update dependencies
Thank you @GrgDev for the contribution!
- [SECURITY] Update dependencies, including
google.golang.org/protobuf
for CVE-2024-24786
This is a maintenance release.
- [CHANGE] Update dependencies: prometheus/common, client model, and Go 1.21
- [FEATURE] Add option to honor original labels from event tags over labels specified in mapping configuration (#521)
Thank you @rabenhorst for the honor_labels
contribution!
- [CHANGE] Update
client_golang
(#508, #513) - [ENHANCEMENT] Process UDP packets asynchronously (#511)
- [BUGFIX] Debug-log incoming lines in cleartext (#510)
- [SECURITY] Update
golang.org/x/net
(#516)
This release is less likely to drop UDP packets under very high traffic.
Additionally, when it does, it now attempts to record that this happened in the metric statsd_exporter_udp_packet_drops_total
, where previously this could only be detected from operating system metrics.
If you are already monitoring for OS-level UDP packet drops, you must also monitor this metric.
The exporter will pull packets from the UDP socket queue much more quickly and queue them internally before processing.
Existing monitoring for packet drops will no longer be sufficient to detect dropped events, but attribution to the exporter is easier with this new metric.
Many thanks to @sumeshpremraj and @kullanici0606 for their contributions, and @pedro-stanaka for helping with the async UDP processing!
- [FEATURE] Improve the landing page experience (#504)
- [FEATURE] Support scaling parameter in mapping (#499)
- [SECURITY] Maintenance release, updating dependencies
- [ENHANCEMENT][library] Allow instantiating configuration without going through YAML (#491)
Version 0.23.2 was mistagged and thus skipped.
- [SECURITY] Update all dependencies (#489)
- [CHANGE] Print help and version to standard out (#469)
- [FEATURE] Support experimental native histograms (#474)
- [BUGFIX] Prevent poisoning with gauge/distribution naming collision (#461)
- [CHANGE] Update
client_golang
dependency (#463)
- [CHANGE] Build with Go 1.18 (#450)
- [CHANGE] Update dependencies (#449)
This is another housekeeping release.
- [ENHANCEMENT] Add metric for total lines relayed (#434)
This release is built with Go 1.17.9, to address security issues in Go.
- [BUGFIX] Make Docker image compatible with the runAsNonRoot setting in Kubernetes pods (#409)
- [BUGFIX] Library: fix support for custom Registerers with histograms and summaries (#410)
- [BUGFIX] Accept metrics with multiple dashes even if not mapped (#402)
- [ENHANCEMENT] Add metrics to relay (#393)
- [ENHANCEMENT] Accept incoming metrics with multiple dashes (with mapping) (#381)
- [ENHANCEMENT] Allow forwarding messages to statsd for easier transition (#388)
- [BUGFIX] Actually expose pprof endpoints (#386)
- [BUGFIX] Fix performance regression on metric ingestion (#390)
- [ENHANCEMENT] Update dependencies & switch to go-kit/log (#379)
This release changes the log format to be more structured, in line with other Prometheus projects.
- [ENHANCEMENT] Use extracted go-kit/log to reduce transitive dependencies (#378)
Once again there is no functional change. For library users, the dependency tree shrinks considerably. See prometheus/common#255 for more details.
- [BUGFIX] Remove copyleft licensed dependency (#375)
There is no functional change for exporter users. Removing this dependency reduces uncertainty for anyone reusing the mapping code.
- [CHANGE] [library] Split mapper caches out from mapper (#363)
- [BUGFIX] Accept metric segments that start with numbers (#365)
- [ENHANCEMENT] Support full defaults for summaries and histograms (#361)
This completes support for summary_options
and histogram_options
.
Change the legacy configuration attributes throughout the mapping configuration as follows:
quantiles: …
tosummary_options: { quantiles: … }
buckets: …
tohistogram_options: { buckets: … }
timer_type
toobserver_type
.
Support for the deprecated attributes will be removed in a future release.
- [BUGFIX] Don't return empty responses to lifecycle api requests (#360)
- [CHANGE] [library] Require explicit Registerer (#347)
- [ENHANCEMENT] Add /-/healthy and /-/ready endpoints (#339)
- [BUGFIX] Do not open network ports when only checking config (#357)
- [ENHANCEMENT] Allow turning off tagging extensions (#325)
- [ENHANCEMENT] Add a lifecycle API for configuration reloads and restarts (#329)
This release changes the interface for the github.com/prometheus/statsd_exporter/pkg/line
library package to support the new configurability.
- [CHANGE] Support non-timer distributions without unit conversion (#314)
- [ENHANCEMENT] Offline configuration check (#312)
- [ENHANCEMENT] Support the SignalFX tagging extension (#315)
- [BUGFIX] Allow matching single-letter metric name components (#309)
Distribution and histogram events (type d
, h
) are now treated as distinct from timer events (type ms
).
Their values are observed as they are, while timer events are converted from milliseconds to seconds.
To reflect this generalization, the observer_type
mapping option replaces timer_type
.
Similary, change match_metric_type: timer
to match_metric_type: observer
.
The old name remains available for compatibility.
For users of the mapper library, the ObserverEvent
replaces TimerEvent
.
For timer metrics, it is emitted by the mapper already converted to seconds.
- [CHANGE] Break out much of the exporter into reusable packages (#298)
- [ENHANCEMENT] Log ingested lines at debug level (#305)
This release mainly consists of an internal reorganization of the exporter. This should not have any impact on users of the binary, if it does, please file an issue.
For users of the existing library packages, nothing changes.
There are now multiple new packages available, exposing functionality that had been locked away in the main package. Consider the interfaces of these libraries preliminary; we will change them as we gain experience in how they are used.
- [ENHANCEMENT] Allow setting granularity for summary metrics (#290)
- [ENHANCEMENT] Support a random-replacement cache invalidation strategy (#281
To facilitate the expanded settings for summaries, the configuration format changes from
mappings:
- match: …
timer_type: summary
quantiles:
- quantile: 0.99
error: 0.001
- quantile: 0.95
error: 0.01
…
to
mappings:
- match: …
timer_type: summary
summary_options:
quantiles:
- quantile: 0.99
error: 0.001
- quantile: 0.95
error: 0.01
…
max_summary_age: 30s
summary_age_buckets: 3
stream_buffer_size: 1000
…
For consistency, the format for histogram buckets also changes from
mappings:
- match: …
timer_type: histogram
buckets: [ 0.01, 0.025, 0.05, 0.1 ]
to
mappings:
- match: …
timer_type: histogram
histogram_options:
buckets: [ 0.01, 0.025, 0.05, 0.1 ]
Transitionally, the old format will still work but is deprecated. The new settings are optional.
For users of the mapper
as a library, this is a breaking change. To adjust your code, replace
mapping.Buckets
with mapping.HistogramOptions.Buckets
and
mapping.Quantiles
with mapping.SummaryOptions.Quantiles
.
- [BUGFIX] Mapper cache poisoning when name is variable (#286)
- [BUGFIX] nil pointer dereference in UDP listener (#287)
Thank you to everyone who reported these, and @bakins for the mapper cache fix!
- [CHANGE] Switch logging to go-kit (#283)
- [CHANGE] Rename existing metric for mapping cache size (#284)
- [ENHANCEMENT] Add metrics for mapping cache hits (#280)
Logs are more structured now. The fatal
log level no longer exists; use --log.level=error
instead. The valid log formats are logfmt
and json
.
The metric statsd_exporter_cache_length
is now called statsd_metric_mapper_cache_length
.
- [ENHANCEMENT] Support sampling factors for all statsd metric types (#264)
- [ENHANCEMENT] Support Librato and InfluxDB labeling formats (#267)
Thank you to everyone who reported and helped debug these issues!
- [BUGFIX] Renew TTL when a metric receives updates (#246)
- [CHANGE] Reload on SIGHUP instead of watching the file (#243)
- [BUGFIX] Fix TCP handler (#235)
- [ENHANCEMENT] Batch event processing for improved ingestion performance (#227)
- [ENHANCEMENT] Switch Prometheus client to promhttp, freeing the standard HTTP metrics (#233)
With #233, the exporter no longer exports metrics about its own HTTP status. These were not helpful since you could not get them when scraping fails. This allows mapping to metric names like http_requests_total
that are useful as application metrics.
- [BUGFIX] Fix mapping collision for metrics with different types, but the same name (#229)
- [BUGFIX] Fix "Error: inconsistent label cardinality: expected 0 label values but got N in prometheus.Labels" (#224)
- [BUGFIX] Revert #218 due to a race condition (#221)
- [ENHANCEMENT] Reduce allocations when escaping metric names (#217)
- [ENHANCEMENT] Reduce allocations when handling packets (#218)
- [ENHANCEMENT] Optimize label sorting (#219)
This release is entirely powered by @claytono. Kudos!
- [CHANGE] Do not run as root in the Docker container by default (#202)
- [FEATURE] Add metric for count of events by action (#193)
- [FEATURE] Add metric for count of distinct metric names (#200)
- [FEATURE] Add UNIX socket listener support (#199)
- [FEATURE] Accept Datadog distributions (#211)
- [ENHANCEMENT] Add a health check to the Docker container (#182)
- [ENHANCEMENT] Allow inconsistent label sets (#194)
- [ENHANCEMENT] Speed up sanitization of metric names (#197)
- [ENHANCEMENT] Enable pprof endpoints (#205)
- [ENHANCEMENT] DogStatsD tag parsing is faster (#210)
- [ENHANCEMENT] Cache mapped metrics (#198)
- [BUGFIX] Fix panic if a mapping resulted in an empty name (#192)
- [BUGFIX] Ensure that there are always default quantiles if using summaries (#212)
- [BUGFIX] Prevent ingesting conflicting metric types that would make scraping fail (#213)
With #192, the count of events rejected because of negative counter increments has moved into the statsd_exporter_events_error_total
metric, instead of being lumped in with the different kinds of successful events.
- [ENHANCEMENT] Update the Prometheus client library to 0.9.2 (#171)
- [FEATURE] Metrics can now be expired with a per-mapping TTL (#164)
- [CHANGE] Timers that mapped to a summary are scaled to seconds, just like histograms (#178)
If you are using summaries, all your quantiles and _total
will change by a factor of 1000.
Adjust your queries and dashboards, or consider switching to histograms altogether.
- [BUGFIX] Expose the counter for unmapped matches (#161)
- [BUGFIX] Unsuccessful backtracking does not clobber captures (#169, fixes #168)
- [ENHANCEMENT] Speed up glob matching (#157)
This release replaces the implementation of the glob matching mechanism, speeding it up significantly. In certain sub-optimal configurations, a warning is logged.
This major enhancement was contributed by Wangchong Zhou.
This is a breaking release, but the migration is easy: command line flags now
require two dashes (--help
instead of -help
). The previous flag library
already accepts this form, so if necessary you can migrate the flags first
before upgrading.
The deprecated --statsd.listen-address
flag has been removed, use
--statsd.listen-udp
instead.
- [CHANGE] Switch to Kingpin for flags, fixes setting log level (#141)
- [ENHANCEMENT] Allow matching on specific metric types (#136)
- [ENHANCEMENT] Summary quantiles can be configured (#135)
- [BUGFIX] Fix panic if an invalid regular expression is supplied (#126)
NOTE: This release breaks backward compatibility. statsd_exporter
now uses
a YAML configuration file. You must convert your mappings configuration to
the new format when you upgrade. For example, the configuration
test.dispatcher.*.*.*
name="dispatcher_events_total"
processor="$1"
action="$2"
outcome="$3"
job="test_dispatcher"
*.signup.*.*
name="signup_events_total"
provider="$2"
outcome="$3"
job="${1}_server"
now has the format
mappings:
- match: test.dispatcher.*.*.*
help: "The total number of events handled by the dispatcher."
name: "dispatcher_events_total"
labels:
processor: "$1"
action: "$2"
outcome: "$3"
job: "test_dispatcher"
- match: *.signup.*.*
name: "signup_events_total"
help: "The total number of signup events."
labels:
provider: "$2"
outcome: "$3"
job: "${1}_server"
The help field is optional.
There is a tool available to help with this conversion.
- [CHANGE] Replace the overloaded "packets" metric (#106)
- [CHANGE] Removed
-statsd.add-suffix
option flag #99. Users should remove this flag when upgrading. Metrics will no longer automatically include the suffixes_timer
orcounter
. You may need to adjust any graphs that used metrics with these suffixes. - [CHANGE] Reduce log levels #92. Many log events have been changed from error to debug log level.
- [CHANGE] Use YAML for configuration file #66. See note above about file format conversion.
- [ENHANCEMENT] Allow help text to be customized #87
- [ENHANCEMENT] Add support for regex mappers #85
- [ENHANCEMENT] Add TCP listener support #71
- [ENHANCEMENT] Allow histograms for timer metrics #66
- [ENHANCEMENT] Added support for sampling factor on timing events #28
- [BUGFIX] Conflicting label sets no longer crash the exporter and will be ignored. Restart to clear the remembered label set. #72
- [ENHANCEMENT] Improve mapping configuration parser #61
- [ENHANCEMENT] Add increment/decrement support to Gauges #65
- [BUGFIX] Tolerate more forms of broken lines from StatsD #48
- [BUGFIX] Skip metrics with invalid utf8 #50
- [BUGFIX] ListenAndServe now fails on exit #58
- [CHANGE] Drop
_count
suffix forloaded_mappings
metric (#41) - [ENHANCEMENT] Use common's log and version packages, and add -version flag (#44)
- [ENHANCEMENT] Add flag to disable metric type suffixes (#37)
- [BUGFIX] Increase receivable UDP datagram size to 65535 bytes (#36)
- [BUGFIX] Warn, not panic when negative number counter is submitted (#33)
NOTE: This release renames statsd_bridge
to statsd_exporter
- [CHANGE] New Dockerfile using alpine-golang-make-onbuild base image (#17)
- [ENHANCEMENT] Allow configuration of UDP read buffer (#22)
- [BUGFIX] allow metrics with dashes when mapping (#24)
- [ENHANCEMENT] add root endpoint with redirect (#25)
- [CHANGE] rename bridge to exporter (#26)
- Initial release