#prometheus-metrics #open-metrics #prometheus #metrics #monitoring #instrumentation

prometheus-client

Open Metrics client library allowing users to natively instrument applications

20 releases

new 0.23.1 Jan 15, 2025
0.22.3 Jul 17, 2024
0.22.2 Mar 7, 2024
0.22.0 Oct 25, 2023
0.15.1 Feb 4, 2022

#67 in Debugging

Download history 116059/week @ 2024-09-27 139084/week @ 2024-10-04 135529/week @ 2024-10-11 141409/week @ 2024-10-18 135117/week @ 2024-10-25 133054/week @ 2024-11-01 130521/week @ 2024-11-08 124648/week @ 2024-11-15 124216/week @ 2024-11-22 126525/week @ 2024-11-29 136733/week @ 2024-12-06 130484/week @ 2024-12-13 60572/week @ 2024-12-20 57762/week @ 2024-12-27 117625/week @ 2025-01-03 150522/week @ 2025-01-10

408,307 downloads per month
Used in 454 crates (80 directly)

Apache-2.0 OR MIT

175KB
3.5K SLoC

Prometheus Rust client library

Test Status Crate API

Rust client library implementation of the Open Metrics specification. Allows developers to instrument applications and thus enables operators to monitor said applications with monitoring systems like Prometheus.

Documentation: https://docs.rs/prometheus-client/

Goals

  • No unsafe. Don't use unsafe Rust within the library itself.

  • Type safe. Leverage Rust's type system to catch common instrumentation mistakes at compile time.

  • Fast. Don't force users to worry about the performance impact of instrumentation. Instead encourage users to instrument often and extensively.

Specification Compliance

Below is a list of properties where this client library implementation lags behind the Open Metrics specification. Not being compliant with all requirements (MUST and MUST NOT) of the specification is considered a bug and likely to be fixed in the future. Contributions in all forms are most welcome.

  • State set metric.

  • Enforce "A Histogram MetricPoint MUST contain at least one bucket".

  • Enforce "A MetricFamily MUST have a [...] UNIT metadata".

  • Enforce "MetricFamily names [...] MUST be unique within a MetricSet."

  • Enforce "Names SHOULD be in snake_case".

  • Enforce "MetricFamily names beginning with underscores are RESERVED and MUST NOT be used unless specified by this standard".

  • Enforce "Exposers SHOULD avoid names that could be confused with the suffixes that text format sample metric names use".

  • Gauge histogram metric.

  • Allow "A MetricPoint in a Metric with the type [Counter, Histogram] SHOULD have a Timestamp value called Created".

  • Summary metric.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0.6–6MB
~39K SLoC