Pedestal metrics are a wrapper around {otel}, which provides cross-platform solutions for metrics, tracing, and logging [1] which defines the protocol that can be implemented to capture metrics without using Open Telemetry.].
Metrics and tracing are provided in the io.pedestal/pedestal.telemetry library.
The api:*[] namespace contains the API that applications can use to emit metrics.
Pedestal supports:
A numeric value that increases over time, such as the number of requests processed.
Measures value that varies over time, such as the depth of a queue.
Measures a duration and a count, used for things like request processing time.
Tracks a range of values, exposing them in different bucket ranges; useful for identifying broad trends, and used for metrics such as size of incoming requests.
The metrics API is built around the api:*default-metric-source*[], which is created at startup from a function identified by runtime configuration.
{otel} defines a wide range of JVM system properties and environment variables to configure metrics (and tracing); those are outside the scope of this document.
Rather than rely on outside configuration, an application can provide its own initialization function to setup Open Telemetry as needed.
The {otel} framework supports long or double as the value types inside metrics; Pedestal expects any underlying metrics framework to do the same, even if it means converting provided value types.
By default, metric values are of type long. This can be overridden using configuration.
In addition, the attribute :io.pedestal.metrics/value-type can be applied to any metric; the value for the attribute should be either :long or :double.
Pedestal will convert supplied longs or doubles to the correct type for the particular metric.
Pedestal has a small amount of built-in metrics.
A counter of the number of incoming requests, produced by the api:log-request[ns=io.pedestal.http] interceptor.
A counter for the number of requests that are allowed, produced by the api:allow-origin[ns=io.pedestal.http.cors] interceptor.
A counter for number of uncaught exceptions thrown during interceptor execution.
A gauge measuring the number of active requests in progress at any one time.
A histogram measuring the size of server-sent messages sent to the client.
A gauge of the number of active streams sending server-sent messages.
A counter of the number of times that the asynchrounous pipe to a client closed during delivery of a streaming response.
Can you improve this documentation?Edit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |