UNPKG

4.61 kBMarkdownView Raw
1# winston-loki
2
3[![npm version](https://badge.fury.io/js/winston-loki.svg)](https://badge.fury.io/js/winston-loki)
4[![install size](https://packagephobia.now.sh/badge?p=winston-loki)](https://packagephobia.now.sh/result?p=winston-loki)
5[![Build Status](https://travis-ci.com/JaniAnttonen/winston-loki.svg?branch=master)](https://travis-ci.com/JaniAnttonen/winston-loki)
6[![Coverage Status](https://coveralls.io/repos/github/JaniAnttonen/winston-loki/badge.svg?branch=master)](https://coveralls.io/github/JaniAnttonen/winston-loki?branch=master)
7[![Maintainability](https://api.codeclimate.com/v1/badges/17a55cce14d581c308bc/maintainability)](https://codeclimate.com/github/JaniAnttonen/winston-loki/maintainability)
8
9A Grafana Loki transport for the nodejs logging library Winston.
10
11## Usage
12This Winston transport is used similarly to other Winston transports. Require winston and define a new LokiTransport() inside its options when creating it.
13
14### [Examples](./examples/)
15Several usage examples with a test configuration for Grafana+Loki+Promtail reside under [`examples/`](./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.
16
17### Options
18LokiTransport() takes a Javascript object as an input. These are the options that are available, __required in bold__:
19
20| **Parameter** | **Description** | **Example** | **Default** |
21| ------------------ | --------------------------------------------------------- | -----------------------| ------------- |
22| __`host`__ | URL for Grafana Loki | http://127.0.0.1:3100 | null |
23| `interval` | The interval at which batched logs are sent in seconds | 30 | 5 |
24| `json` | Use JSON instead of Protobuf for transport | true | false |
25| `batching` | If batching is not used, the logs are sent as they come | true | true |
26| `clearOnError` | Discard any logs that result in an error during transport | true | false |
27| `replaceTimestamp` | Replace any log timestamps with Date.now() | true | false |
28| `labels` | custom labels, key-value pairs | { module: 'http' } | undefined |
29| `format` | winston format (https://github.com/winstonjs/winston#formats) | simple() | undefined |
30| `gracefulShutdown` | Enable/disable graceful shutdown (wait for any unsent batches) | false | true |
31| `timeout` | timeout for requests to grafana loki in ms | 30000 | undefined |
32| `basicAuth` | basic authentication credentials to access Loki over HTTP | username:password | undefined |
33| `onConnectionError`| Loki error connection handler | (err) => console.error(err) | undefined |
34
35### Example
36With default formatting:
37```js
38const { createLogger, transports } = require("winston");
39const LokiTransport = require("winston-loki");
40const options = {
41 ...,
42 transports: [
43 new LokiTransport({
44 host: "http://127.0.0.1:3100"
45 })
46 ]
47 ...
48};
49const logger = createLogger(options);
50```
51
52You can set custom labels in every log as well like this:
53```js
54logger.debug({ message: 'test', labels: { 'key': 'value' } })
55```
56
57TODO: Add custom formatting example
58
59## Developing
60### Requirements
61Running 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.
62
63Refer to https://grafana.com/docs/loki/latest/api/ for documentation about the available endpoints, data formats etc.
64
65### Example
66```sh
67npm install
68npm link
69cd ~/your_project
70npm link winston-loki
71npm install
72```
73And you should have a working, requirable winston-loki package under your project's node_modules.
74After the link has been established, any changes to winston-loki should show on rerun of the software that uses it.
75
76### Run tests
77```sh
78npm test
79```
80
81Write new ones under `/test`