Skip to content

Express middleware to collect data inside InfluxDB and render in a Grafana dashboard.

License

Notifications You must be signed in to change notification settings

jorma16/express-metrics

Repository files navigation

Express metrics

With this project you can connect your express application with influxdb and render a dashboard in grafana.

By default it gather a classic group of parameters, like request duration, code, bytes, url, domain and referer. It also allow you to create custom functions to gather other metrics.

You can install this with npm i mtrics-express and see in npm

Basic use

You can easily add this module as a middleware of your express app, without any config, only naming your metric for example with the name of your project. You can go to the examples/basic folder to see an example.

Advanced use

If you need more funcionality, you can go to examples/custom-config to see an example of an advanced use of the library to extends the metrics gathered by the middleware. Yo need to specify in your config file the schema of the measurement and your custom transform function needs to receive as params the request and the response, and needs to return an array with [tags, fields] as objects.

Example of custom config file

module.exports = {
  measurement: {
    name: 'express'
  },
  schema: {
    userEmail: 'string'
  }
};

Here we can see that the name of the measurement is express and the extended schema accemts a new field named userEmail and his type is string it allows more types like:

  • float (f)
  • boolean (b)
  • integer (i)
  • string (s)
const influx = require('../../src')(config, (req, res) => {
  return [{}, { userEmail: req.user }];
});

const app = express();
app.use(influx);

Here we can see how to configure our express application, for example passing the previous config file and adding a transform function that returns an array with an empty object as extended tags and an object with our new metric in the fields object.

If you want, can apply a blacklist in your config file, to allow the middleware to do not track some user-agents.

module.exports = {
  measurement: {
    name: 'express'
  },
  schema: {
    userEmail: 'string'
  },
  blackList: ['your-custom-user-agent']
};

Requeriments

This library is thought to be used with an influxDb database and a grafana dashboard to paint the metrics is included in the project in the dashboard.json file, ready to be imported.

Dependencies

This library uses:

  • geoip-lite 1.4.7: To geolocalize the ip directions and be able to draw on a map.
  • influxdb-nodejs 3.1.0: Connectivity layer with influx
  • on-headers 1.0.2: Easily manage the response just before we send it.
  • lodash 4.17.21: Utility library

Contributions

This project exists thanks to the following people:

About

Express middleware to collect data inside InfluxDB and render in a Grafana dashboard.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published