prometheus: Prometheus Haskell Client
- Prometheus Haskell Client
A simple and modern, type safe, performance focused, idiomatic Haskell client for Prometheus monitoring. Specifically there is no use of unsafe IO or manual ByteString construction from lists of bytes. Batteries-included web server.
A key design element of this library is that the RegistryT monad transformer is only required for registering new time series. Once the time series is registered, new data samples may just be added in the IO monad.
Note: Version 0.* supports Prometheus v1.0 and version 2.* supports Prometheus v2.0.
- Usage Example
module Example where
import           Control.Monad.IO.Class                         (liftIO)
import           System.Metrics.Prometheus.Http.Scrape          (serveMetricsT)
import           System.Metrics.Prometheus.Concurrent.RegistryT
import           System.Metrics.Prometheus.Metric.Counter       (inc)
import           System.Metrics.Prometheus.MetricId
main :: IO ()
main = runRegistryT $ do
    -- Labels can be defined as lists or added to an empty label set
    connectSuccessGauge <- registerGauge "example_connections" (fromList [("login", "success")])
    connectFailureGauge <- registerGauge "example_connections" (addLabel "login" "failure" mempty)
    connectCounter <- registerCounter "example_connection_total" mempty
    latencyHistogram <- registerHistogram "example_round_trip_latency_ms" mempty [10, 20..100]
    liftIO $ inc connectCounter -- increment a counter
    -- [...] pass metric handles to the rest of the app
    serveMetricsT 8080 ["metrics"] -- http://localhost:8080/metric server
- Advanced Usage
A Registry and StateT-based RegistryT are available for unit testing or generating lists
of `[IO a]` actions that can be sequenced and returned from pure code to be applied.
[Skip to Readme]
Modules
[Index] [Quick Jump]
- System- Metrics
 
Flags
Automatic Flags
| Name | Description | Default | 
|---|---|---|
| buildexamples | Build the Example.hs file. This is normally only used for testing. | Disabled | 
Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info
Downloads
- prometheus-2.3.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
For package maintainers and hackage trustees
Candidates
- No Candidates
| Versions [RSS] | 0.1.0.0, 0.1.0.1, 0.1.0.2, 0.1.0.3, 0.1.1, 0.2.0, 0.3.0, 0.3.1, 0.3.2, 0.3.2.1, 0.4.0, 0.4.1, 0.4.2, 0.5.0, 2.0.0, 2.0.1, 2.0.2, 2.1.0, 2.1.1, 2.1.2, 2.1.3, 2.2.1, 2.2.2, 2.2.3, 2.2.4, 2.3.0 | 
|---|---|
| Dependencies | atomic-primops (>=0.8 && <0.9), base (>=4.9 && <5), bytestring (>=0.10 && <0.13), containers (>=0.5 && <0.8), http-client (>=0.4 && <0.8), http-client-tls (>=0.3 && <0.4), http-types (>=0.8 && <0.13), network-uri (>=2.5 && <2.7), prometheus, text (>=1.2 && <2.2), transformers (>=0.4 && <0.7), wai (>=3.2 && <3.3), warp (>=3.2 && <3.5) [details] | 
| License | BSD-3-Clause | 
| Copyright | Bitnomial, Inc. (c) 2016-2023 | 
| Author | Luke Hoersten | 
| Maintainer | luke@bitnomial.com, opensource@bitnomial.com | 
| Category | Metrics, Monitoring, Web, System | 
| Home page | http://github.com/bitnomial/prometheus | 
| Bug tracker | http://github.com/bitnomial/prometheus/issues | 
| Source repo | head: git clone https://github.com/bitnomial/prometheus | 
| Uploaded | by wraithm at 2024-08-07T17:50:14Z | 
| Distributions | LTSHaskell:2.3.0, NixOS:2.3.0, Stackage:2.3.0 | 
| Reverse Dependencies | 6 direct, 1 indirect [details] | 
| Executables | prometheus-example | 
| Downloads | 25097 total (133 in the last 30 days) | 
| Rating | 2.25 (votes: 2) [estimated by Bayesian average] | 
| Your Rating | |
| Status | Docs available [build log] Last success reported on 2024-08-07 [all 1 reports] |