@pbinj/pbj-metrics
v1.0.3
Published
A @pbinj/pbj extension for prometheus metrics.
Downloads
141
Maintainers
Readme
@pbinj/pbj-prom
A Prometheus metrics extension for @pbinj/pbj, providing easy integration of Prometheus monitoring into your PBinJ-based applications.
Features
- 🔍 Easy integration with Prometheus
- 📊 Pre-configured metrics collectors
- 🎯 Type-safe metric registration
- 🔄 Automatic metric aggregation
- 🪝 Built-in middleware support
- 🎛️ Configurable default metrics
Installation
npm install @pbinj/pbj-prom prom-client
pnpm add @pbinj/pbj-prom prom-client
yarn add @pbinj/pbj-prom prom-client
Note: prom-client
is a peer dependency and must be installed separately.
Quick Start
import { pbj, context } from "@pbinj/pbj";
import { promClientPBinJKey } from "@pbinj/pbj-prom";
// Get the Prometheus client
const prometheus = pbj(promClientPBinJKey);
// Create and register metrics
const httpRequestsTotal = new prometheus.Counter({
name: "http_requests_total",
help: "Total number of HTTP requests",
labelNames: ["method", "status"],
});
// Use in your service
class MetricsService {
constructor(private prometheus = pbj(promClientPBinJKey)) {
// Initialize metrics
}
recordRequest(method: string, status: number) {
httpRequestsTotal.inc({ method, status });
}
}
Running Prometheus
A Docker configuration is included for local development. To start Prometheus:
npm run prometheus
This will start Prometheus with the included configuration, accessible at http://localhost:9090
.
Configuration
prometheus.yml
The default Prometheus configuration is set to scrape metrics from localhost:9464
. You can modify the configuration in prometheus.yml
:
global:
scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
alerting:
alertmanagers:
- static_configs:
- targets:
rule_files:
scrape_configs:
- job_name: "prometheus"
static_configs:
- targets: ["localhost:9090"]
Custom Metrics
import { pbj } from "@pbinj/pbj";
import { promClientPBinJKey } from "@pbinj/pbj-prom";
class CustomMetricsService {
private prometheus = pbj(promClientPBinJKey);
private requestDuration = new this.prometheus.Histogram({
name: "http_request_duration_seconds",
help: "HTTP request duration in seconds",
labelNames: ["method", "route"],
buckets: [0.1, 0.5, 1, 2, 5],
});
recordDuration(method: string, route: string, duration: number) {
this.requestDuration.observe({ method, route }, duration);
}
}
Express Middleware Example
import { pbj } from "@pbinj/pbj";
import { promClientPBinJKey } from "@pbinj/pbj-prom";
import express from "express";
const app = express();
const prometheus = pbj(promClientPBinJKey);
// Metrics endpoint
app.get("/metrics", async (req, res) => {
res.set("Content-Type", prometheus.register.contentType);
res.end(await prometheus.register.metrics());
});
// Middleware to collect metrics
app.use((req, res, next) => {
const start = Date.now();
res.on("finish", () => {
const duration = Date.now() - start;
// Record metrics here
});
next();
});
API Reference
Keys
promClientPBinJKey
: Access the Prometheus client instanceaggregatorRegistryKey
: Access the metrics aggregator registry
Types
The package exports all types from prom-client
for type-safe metric creation.
Development
# Install dependencies
pnpm install
# Run tests
pnpm test
# Build
pnpm build
# Start Prometheus
pnpm run docker
Testing
pnpm test
License
MIT
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.