6.1.2 • Published 4 days ago

winston-loki v6.1.2

Weekly downloads
1,592
License
MIT
Repository
github
Last release
4 days ago

winston-loki

npm version install size Build Status Coverage Status Maintainability

A Grafana Loki transport for the nodejs logging library Winston.

Usage

This Winston transport is used similarly to other Winston transports. Require winston and define a new LokiTransport() inside its options when creating it.

Examples

Several usage examples with a test configuration for Grafana+Loki+Promtail reside under examples/. If you want the simplest possible configuration, that's probably the place to check out. By defining json: true and giving winston-loki the correct host address for Loki is enough for most.

Options

LokiTransport() takes a Javascript object as an input. These are the options that are available, required in bold:

ParameterDescriptionExampleDefault
hostURL for Grafana Lokihttp://127.0.0.1:3100null
intervalThe interval at which batched logs are sent in seconds305
jsonUse JSON instead of Protobuf for transporttruefalse
batchingIf batching is not used, the logs are sent as they cometruetrue
clearOnErrorDiscard any logs that result in an error during transporttruefalse
replaceTimestampReplace any log timestamps with Date.now(). Warning: Disabling replaceTimestamp may result in logs failing to upload due to recent changes in the upstream Loki project. It is recommended to leave this option enabled unless you have a specific reason to disable it.truetrue
labelscustom labels, key-value pairs{ module: 'http' }undefined
formatwinston format (https://github.com/winstonjs/winston#formats)simple()undefined
gracefulShutdownEnable/disable graceful shutdown (wait for any unsent batches)falsetrue
timeouttimeout for requests to grafana loki in ms30000undefined
basicAuthbasic authentication credentials to access Loki over HTTPusername:passwordundefined
onConnectionErrorLoki error connection handler(err) => console.error(err)undefined
useWinstonMetaAsLabelsUse Winston's "meta" (such as defaultMeta values) as Loki labelstruefalse
ignoredMetaWhen useWinstonMetaAsLabels is enabled, a list of meta values to ignore"error_description"undefined

Example

With default formatting:

const { createLogger, transports } = require("winston");
const LokiTransport = require("winston-loki");
const options = {
  ...,
  transports: [
    new LokiTransport({
      host: "http://127.0.0.1:3100"
    })
  ]
  ...
};
const logger = createLogger(options);

You can set custom labels in every log as well like this:

logger.debug({ message: 'test', labels: { 'key': 'value' } })

TODO: Add custom formatting example

Developing

Requirements

Running a local Loki for testing is probably required, and the easiest way to do that is to follow this guide: https://github.com/grafana/loki/tree/master/production#run-locally-using-docker. After that, Grafana Loki instance is available at http://localhost:3100, with a Grafana instance running at http://localhost:3000. Username admin, password admin. Add the Loki source with the URL http://loki:3100, and the explorer should work.

Refer to https://grafana.com/docs/loki/latest/api/ for documentation about the available endpoints, data formats etc.

Example

npm install
npm link
cd ~/your_project
npm link winston-loki
npm install

And you should have a working, requirable winston-loki package under your project's node_modules. After the link has been established, any changes to winston-loki should show on rerun of the software that uses it.

Run tests

npm test

Write new ones under /test

6.1.2

4 days ago

6.1.1

12 days ago

6.1.0

19 days ago

6.0.8

6 months ago

6.0.7

9 months ago

6.0.7-rc2

1 year ago

6.0.7-rc1

1 year ago

6.0.6

2 years ago

6.0.5

2 years ago

6.0.4

2 years ago

6.0.3

2 years ago

6.0.2

3 years ago

6.0.1

3 years ago

6.0.0

3 years ago

6.0.0-rc.9

3 years ago

6.0.0-rc.8

3 years ago

6.0.0-rc.7

3 years ago

6.0.0-rc.6

4 years ago

6.0.0-rc.5

4 years ago

6.0.0-rc.4

4 years ago

6.0.0-rc.3

4 years ago

6.0.0-rc.2

4 years ago

6.0.0-rc.1

4 years ago

5.1.2

4 years ago

5.1.1

4 years ago

5.1.0

4 years ago

5.0.0

4 years ago

4.0.2

4 years ago

4.0.1

5 years ago

4.0.0

5 years ago

3.0.1

5 years ago

3.0.0

5 years ago

3.0.0-rc-1

5 years ago

2.2.2

5 years ago

2.2.2-rc1

5 years ago

2.2.1

5 years ago

2.2.0

5 years ago

2.1.3

5 years ago

2.1.2

5 years ago

2.1.1

5 years ago

2.1.0

5 years ago

2.0.3

5 years ago

2.0.2

5 years ago

2.0.1

5 years ago

2.0.0

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago

0.0.3

5 years ago

0.0.2

5 years ago

0.0.1

5 years ago