NestJS module for Prometheus
npm install @willsoto/nestjs-prometheus
- Installation
- Usage
- Changing the metrics http endpoint
- Disabling default metrics collection
- Configuring the default metrics
- Injecting individual metrics
- Setting default labels
- Prefixing custom metrics
- Option 1 (recommended)
- Option 2 (not recommended)
- Available metrics
- Counter
- Gauge
- Histogram
- Summary
- Providing a custom controller
- Pushgateway
``bash`
yarn add @willsoto/nestjs-prometheus prom-client
`bash`
npm install @willsoto/nestjs-prometheus prom-client
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
@Module({
imports: [PrometheusModule.register()],
})
export class AppModule {}
`
By default, this will register a /metrics endpoint that will return the default metrics.
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
@Module({
imports: [
PrometheusModule.register({
path: "/mymetrics",
}),
],
})
export class AppModule {}
`
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
@Module({
imports: [
PrometheusModule.register({
defaultMetrics: {
enabled: false,
},
}),
],
})
export class AppModule {}
`
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
@Module({
imports: [
PrometheusModule.register({
defaultMetrics: {
// See https://github.com/siimon/prom-client#configuration
config: {},
},
}),
],
})
export class AppModule {}
`
`typescript
// module.ts
import { Module } from "@nestjs/common";
import {
PrometheusModule,
makeCounterProvider,
} from "@willsoto/nestjs-prometheus";
import { Service } from "./service";
@Module({
imports: [PrometheusModule.register()],
providers: [
Service,
makeCounterProvider({
name: "metric_name",
help: "metric_help",
}),
],
})
export class AppModule {}
`
`typescript
// service.ts
import { Injectable } from "@nestjs/common";
import { InjectMetric } from "@willsoto/nestjs-prometheus";
import { Counter } from "prom-client";
@Injectable()
export class Service {
constructor(@InjectMetric("metric_name") public counter: Counter
}
`
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
@Module({
imports: [
PrometheusModule.register({
defaultLabels: {
app: "My app",
},
}),
],
})
export class AppModule {}
`
See the docs for more information.
You can add a custom prefix to all custom metrics by providing the customMetricPrefix option to the module configuration.
Some caveats:
In order to have the custom metrics registered in different modules from where the PrometheusModule was registered, you must do one of a few things:
1. Add the PrometheusModule to the exports of the registering Module. It may be useful to create a CommonModule that registers and exports the PrometheusModule.
2. Import that module into whatever module you are creating the custom metrics.
1. Mark the PrometheusModule as global
#### Counter
`typescript`
import { makeCounterProvider } from "@willsoto/nestjs-prometheus";
#### Gauge
`typescript`
import { makeGaugeProvider } from "@willsoto/nestjs-prometheus";
#### Histogram
`typescript`
import { makeHistogramProvider } from "@willsoto/nestjs-prometheus";
#### Summary
`typescript`
import { makeSummaryProvider } from "@willsoto/nestjs-prometheus";
If you need to implement any special logic or have access to the controller (e.g., to customize Swagger),
you can provide your own controller (or subclass) of the default controller.
Here is a basic example which should be enough to extend or customize in any way you might need.
`typescript
// my-custom-controller.ts
import { Controller, Get, Res } from "@nestjs/common";
import { PrometheusController } from "@willsoto/nestjs-prometheus";
import { Response } from "express";
@Controller()
class MyCustomController extends PrometheusController {
@Get()
async index(@Res({ passthrough: true }) response: Response) {
return super.index(response);
}
}
`
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
import { MyCustomController } from "./my-custom-controller";
@Module({
imports: [
PrometheusModule.register({
controller: MyCustomController,
}),
],
})
export class AppModule {}
`
In order to enable Pushgateway for injection, provide the configuration under the pushgateway key.
`typescript
import { Module } from "@nestjs/common";
import { PrometheusModule } from "@willsoto/nestjs-prometheus";
@Module({
imports: [
PrometheusModule.register({
pushgateway: {
url: "http://127.0.0.1:9091",
},
}),
],
})
export class AppModule {}
`
`typescript
import { Injectable } from "@nestjs/common";
import * as client from "prom-client";
@Injectable()
export class Service {
constructor(private readonly pushgateway: client.Pushgateway) {}
}
``