Provide Next.js routes for monitoring and management of your application in Production.
Inspired by rcruzper / express-actuator but tailored for Next.js applications.
ID | Description |
---|---|
info | Displays application information. |
metrics | Shows metrics information for the current application. |
health | Shows application health information. |
npm install --save @bueno-systems/next-actuator
# or
yarn add @bueno-systems/next-actuator
💡 TypeScript types are included
Create a file at ./pages/api/actuator/[...actuator].ts
(or similar) and
return a call to nextActuator()
. Named or default exports are available.
// ./pages/api/actuator/[...actuator].ts
import { nextActuator } from '@bueno-systems/next-actuator'
// Export the handler function with some options
export default nextActuator()
nextActuator({
enableHealth: true, // enable/disable /health endpoint (default true)
enableMetrics: true, // enable/disable /metrics endpoint (default true)
enableInfo: true, // enable/disable /info endpoint (default true)
healthEndpoint: '/health', // change the /health endpoint to something else
metricsEndpoint: '/metrics', // change the /metrics endpoint to something else
infoEndpoint: '/info' // change the /info endpoint to something else
})
GET http://localhost:3000/api/actuator/health
{
"status": "UP"
}
GET http://localhost:3000/api/actuator/info
{
"build": {
"name": "My Cool Project",
"description": "Description from package.json",
"version": "1.2.3"
}
}
GET http://localhost:3000/api/actuator/metrics
{
"mem": {
"rss": 550682624,
"heapTotal": 244232192,
"heapUsed": 213942064,
"external": 191258086,
"arrayBuffers": 188265357
},
"uptime": 2642.679833583
}