📊 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-client
nestjs-metrics-client
is a lightweight, zero-setup alternative to @willsoto/nestjs-prometheus, eliminating 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-client';
ReporterService.counter('api_requests_total', { endpoint: '/users' });
🚀 No Dependency Injection
Unlike @willsoto/nestjs-prometheus, nestjs-metrics-client
removes the need for cumbersome dependency injection, making your code cleaner and more portable.
🌟 Effortless Integration
With zero setup, you can start tracking metrics immediately. No need to configure a service in every file—just use the global ReporterService
.
🎯 Focus on Simplicity
Designed for developers who want powerful metrics without the complexity of managing dependencies or boilerplate code.
Minimal setup required! Just import the ReporterModule
in your AppModule
.
import { Module } from "@nestjs/common";
import { ReporterModule } from 'nestjs-metrics-client';
@Module({
imports: [
ReporterModule.forRoot({
// Default metrics are disabled by default, set to true to enable.
defaultMetricsEnabled: true,
defaultLabels: {
app: 'my-app',
environment: 'production',
}
}),
],
})
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-client';
@Injectable()
export class UserService {
async createUser() {
// Increment user creation counter
ReporterService.counter('users_created_total', {
source: 'api',
user_type: 'standard'
});
// Update active user gauge
ReporterService.gauge('active_users', 42, {
region: 'us-east-1'
});
}
}
The global static service for reporting metrics:
Method | Description | Parameters |
---|---|---|
counter() |
Increment a counter metric | `key: string, labels?: Record<string, string |
gauge() |
Set a gauge value | `key: string, value: number, labels?: Record<string, string |
histogram() |
Record a histogram value | `key: string, value: number, labels?: Record<string, string |
summary() |
Record a summary value | `key: string, value: number, labels?: Record<string, string |
Option | Type | Default | Description |
---|---|---|---|
defaultMetricsEnabled |
boolean |
false |
Enable collection of default metrics |
defaultLabels |
Record<string, string> |
{} |
Labels automatically added to all metrics |
Supports dynamic configuration with factory providers:
ReporterModule.forRootAsync({
useFactory: () => ({
defaultLabels: {
app: process.env.APP_NAME || 'default-app',
environment: process.env.NODE_ENV || 'development',
},
}),
});
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.