📊 A zero-dependency-injection alternative to Prometheus metrics solutions for NestJS.
Effortlessly report metrics from anywhere in your codebase without complex setup or dependency injection.
Overview • Quick Start • API Reference • Contributing • License
npm install nestjs-metrics-reporter
nestjs-metrics-reporter
is a lightweight, zero-setup solution for reporting metrics in your NestJS application.
It eliminates the need for dependency injection or extensive configuration. Instantly report metrics from anywhere in
your application using a global static reporter.
import { ReporterService } from 'nestjs-metrics-reporter';
ReporterService.counter( 'api_requests_total', { endpoint: '/users' } );
graph TD
subgraph Application["Application"]
UserModule[User Module]
ProductModule[Product Module]
UserModule --> ReporterService
ProductModule --> ReporterService
ReporterService --> MetricsService
MetricsService --> Registry["Prometheus Registry (Singleton)"]
MetricsController[/metrics endpoint/] --> Registry
end
Prometheus[Prometheus Scraper] --> MetricsController
MetricsService["Metrics Service (Counters, Gauges, etc.)"]
ReporterService["Reporter Service (Global Wrapper)"]
🚀 No Dependency Injection
No need for cumbersome dependency injection, making your code much more cleaner.
🌟 Effortless Integration
Start tracking metrics immediately with zero setup.
🎯 Focus on Simplicity
Powerful metrics without the complexity of managing dependencies or boilerplate code.
📤 Pushgateway Support
Easily push metrics to a Pushgateway server for batch job metrics.
Minimal setup required! Just import the ReporterModule
in your AppModule
.
import { Module } from "@nestjs/common";
import { ReporterModule } from 'nestjs-metrics-reporter';
@Module( {
imports: [
ReporterModule.forRoot( {
// Default metrics are disabled by default, set to true to enable.
defaultMetricsEnabled: true,
defaultLabels: {
app: 'my-app',
environment: 'production',
},
// Optional: Configure interceptors for custom metrics
interceptors: [ SomeInterceptor ],
// Optional: Configure Pushgateway for batch job metrics
pushgatewayUrl: 'http://pushgateway:9091',
pushgatewayOptions: {
timeout: 5000,
headers: {
'Custom-Header': 'value'
},
auth: {
username: 'user',
password: 'pass'
}
}
} ),
],
} )
export class AppModule {
}
Once initialized, you can start reporting metrics instantly from anywhere in your application.
import { Injectable } from '@nestjs/common';
import { ReporterService } from 'nestjs-metrics-reporter';
@Injectable()
export class UserService {
async createUser() {
// Increment user creation counter
ReporterService.counter( 'users_created_total', {
source: 'api',
user_type: 'standard'
} );
// Increment counter with custom value
ReporterService.counter( 'batch_users_created_total', {
source: 'batch',
user_type: 'standard'
}, 5 );
// Update active user gauge
ReporterService.gauge( 'active_users', 42, {
region: 'us-east-1'
} );
// Push metrics to Pushgateway
await ReporterService.pushMetrics( 'user_service_job' );
}
}
The global static service for reporting metrics:
Method | Description | Parameters |
---|---|---|
counter() |
Increment a counter metric | key: string, labels?: Record<string, string | number>, value?: number = 1 |
gauge() |
Set a gauge value | key: string, value: number, labels?: Record<string, string | number> |
histogram() |
Record a histogram value | key: string, value: number, labels?: Record<string, string | number>, buckets?: number[] |
summary() |
Record a summary value | key: string, value: number, labels?: Record<string, string | number>, percentiles?: number[] |
pushMetrics() |
Push metrics to Pushgateway | jobName: string |
Option | Type | Default | Description |
---|---|---|---|
defaultMetricsEnabled |
boolean |
false |
Enable collection of default metrics |
defaultLabels |
Record<string, string> |
{} |
Labels automatically added to all metrics |
pushgatewayUrl |
string |
undefined |
URL of the Pushgateway server |
pushgatewayOptions |
PushgatewayOptions |
{} |
Additional options for Pushgateway requests |
interceptors |
Type<any>[] |
[] |
Interceptors for custom metrics reporting |
Supports dynamic configuration with factory providers:
ReporterModule.forRootAsync( {
imports: [ ConfigModule ],
inject: [ ConfigService ],
useFactory: () => ( {
defaultLabels: {
app: configService.get( 'APP_NAME' ) || 'default-app',
environment: configService.get( 'NODE_ENV' ) || 'development',
},
pushgatewayUrl: configService.get( 'PUSHGATEWAY_URL' ),
pushgatewayOptions: {
timeout: +configService.get( 'PUSHGATEWAY_TIMEOUT' ) || 5000
}
} ),
} );
This package uses semantic versioning via commit messages:
# Patch Release (1.0.X)
fix: message # Bug fixes
perf: message # Performance improvements
# Minor Release (1.X.0)
feat: message # New features
# Major Release (X.0.0)
feat!: message # Breaking change
fix!: message # Breaking change
BREAKING CHANGE: message # Breaking change anywhere in the commit body
Only these specific types are allowed:
build: message # Changes to build system or dependencies
chore: message # Maintenance tasks
ci: message # CI configuration files and scripts
docs: message # Documentation only
refactor: message # Neither fixes a bug nor adds a feature
style: message # Code style (formatting, semicolons, etc)
test: message # Adding or correcting tests
Any other prefix will cause the commit to be ignored by semantic-release and won't appear anywhere in release notes.
Contributions are welcome! Please check out our Contributing Guide to get started.
This project is licensed under the Apache License, Version 2.0 - see the LICENSE file for details.