Home

Awesome

log4js-influxdb-appender Build Status codecov

NPM

A simple appender for log4js that writes to a InfluxDB database. Built on top of the node-influxdb client.

Installation

npm install log4js
npm install log4js-influxdb-appender

Usage

Default configuration

const log4js = require('log4js');
log4js.configure({
  appenders: {
    influx: {
      type: "log4js-influxdb-appender",
    },
  },
  categories: {
    default: { appenders: ["influx"], level: "trace" },
  },
});
const logger = log4js.getLogger();
logger.debug("important string message"});
logger.trace({ param1: 'can serialize', param2: 'objects too' });

This will result in a message recorded in the database log4js_db, measurement default, of an InfluxDB (running on localhost:8086), as following :

name: default
time                      data                                                  level   pid
----                      -----                                                 ------  ------
2020-05-01T10:13:00.999Z  important string message                              DEBUG   6123
2020-05-01T10:13:01.999Z  { param1: 'can serialize', param2: 'objects too' }    TRACE   6123

Configuration

Examples

const log4js = require('log4js');
log4js.configure({
  appenders: {
    influx: {
      type: 'log4js-influxdb-appender',
      database: 'myDatabase',
      measurement: 'listOfScientists',
      maxBatchSize: 1000,
      fields: ['cheese', 'quantity'],
      tags: ['scientist'],
    },
  },
  categories: {
    default: { appenders: ['influx'], level: 'trace' },
  },
});
const logger = log4js.getLogger();
logger.info({ scientist: 'Marie Curie', cheese: 'roquefort', quantity: '100' });

This will result in a message recorded in the database myDatabase, measurement listOfScientists, of an InfluxDB (running on localhost:8086), as following :

name: listOfScientists
time                     cheese    quantity scientist
----                     ------    -------- ---------
2020-05-16T10:10:14.611Z roquefort 100      Marie Curie

Acknowlegments

License

Released under the MIT License.

Note that node-influxdb dependency has its own licensing.