A Graylog2 or GELF transport for Winston@3.x. Supports HTTP(S) & TCP/TCP over TLS protocols.
If you're looking for the 1.x version supporting Winston < 3.x, check winston-log2gelf@1.9.1.
$ npm install --save winston-log2gelf
const winston = require('winston');
const Log2gelf = require('winston-log2gelf');
const logger = winston.createLogger({
transports: [
new winston.transports.Console({
level: 'info',
handleExceptions: true
}),
new Log2gelf({
level: 'error',
host: '192.168.0.15',
port: 12201,
protocol: 'tls'
})
]
});
Note that if you wish to handle Exceptions, as Winston automatically exits after an exception, you have to disable the exit behaviour to let Log2gelf
enough time to send the log across the network.
const logger = winston.createLogger({
exitOnError: false, // disable default winston exit
transports: [
new winston.transports.Console({
level: 'info',
handleExceptions: true
}),
new Log2gelf({
level: 'error',
host: '192.168.0.15',
port: 12201,
protocol: 'tls',
handleExceptions: true, // handle exception within Log2gelf
exitOnError: true, // exit after exception has been sent
exitDelay: 1000 // leave Log2gelf 1sec to send the message
})
]
});
If used in a script where the process has to naturally exit after its execution, the connection has to be closed (as a db connection would have to) if TCP socket is used. It should be done like so:
const log2gelf = logger.transports.find(transport => transport.name === 'log2gelf');
logger.end = log2gelf.end;
name
: Transport namehostname
: The name of this host (default: os.hostname())host
: The GELF server address (default: 127.0.0.1)port
: The GELF server port (default: 12201)protocol
: Protocol used to send data (tcp
,tls
[TCP over TLS],http
orhttps
). (default: tcp)reconnect
: Number of tcp reconnect attempts (default 0, 0 for none, -1 for infinite)wait
: Milliseconds to wait between reconnect attempts (default 1000)level
: Level of messages this transport should log. See winston levels (default: info)silent
: Boolean flag indicating whether to suppress output. (default: false)handleExceptions
: Boolean flag, whether to handle uncaught exceptions. (default: false)exitOnerror
: Will exit after x ms (2 sec by default) if WinstonexitOnError
is set tofalse
if an exception is caughtexitDelay
: Specify the exit delay in ms forexitOnerror
option. (default 2000ms)service
: as facility is depreacated, service describes what kind of "service" this is (like MySQLd or Apache2). (default: nodejs*service
: as facility is depreacated, service describes what kind of "service" this is (like MySQLd or Apache2). (default: nodejs*service
: as facility is depreacated, service describes what kind of "service" this is (like MySQLd or Apache2). (default: nodejs*service
: as facility is depreacated, service describes what kind of "service" this is (like MySQLd or Apache2). (default: nodejs)environment
: the environment on which your service is running. (default: development)release
: the version of your service (e.g. 1.0.0)._foo
: any underscore-prefixed custom option will be passed as is to the server.
There's sure room for improvement, so feel free to hack around and submit PRs! Please just follow the style of the existing code, which is Airbnb's style with minor modifications.
To maintain things clear and visual, please follow the git commit template.