Graylog: Using with Node.js
How to send logs from Node.js to Graylog
👋 Welcome to the Stackhero documentation!
Stackhero offers a ready-to-use Graylog cloud solution that provides a host of benefits, including:
- Unlimited and dedicated SMTP email server included.
- Effortless updates with just a click.
- Customisable domain name secured with HTTPS (for example, https://logs.your-company.com).
- Optimal performance and robust security powered by a private and dedicated VM.
Save time and simplify your life: it only takes 5 minutes to try Stackhero's Graylog cloud hosting solution!
Sending Node.js logs to Graylog with the graylog2 package (recommended)
Sending logs from Node.js to Graylog is quite straightforward. In this example, you will see how to use the graylog2 package to make this process seamless.
To get started, you can install the package by running the following command:
npm install graylog2
Here is how you can use it to log messages:
const graylog2 = require('graylog2');
const crypto = require('crypto');
const logger = new graylog2.graylog({
servers: [{ host: '<XXXXXX>.stackhero-network.com', port: 12201 }] // Make sure to replace "host" with your Graylog domain
});
// Send a simple message to Graylog
logger.log('Simple message example');
// Attach data to a message
logger.log(
'Password recovery email', // Message
// A JSON object with additional details
{
subject: 'Password recovery',
language: 'en_US',
domain: 'gmail.com'
}
);
// Advanced example
const ip = '1.2.3.4';
const ipHash = crypto.createHash('md5').update(ip).digest('hex');
const userId = '1234';
const userIdHash = crypto.createHash('md5').update(userId).digest('hex');
logger.log(
'API request', // Message
// A JSON object with more details
{
route: '/v1/messages/1234/',
method: 'POST',
responseTime: 12, // ms
responseCode: 200,
ipHash,
userIdHash
}
);
// Log uncaught exceptions in Node.js
process.on(
'uncaughtException',
err => {
logger.log(
err,
{ type: 'uncaughtException' }
);
}
);
For more examples, you can visit this GitHub repository.
warning Do not forget to configure your Graylog input (details below).
Using the Winston GELF package to send Node.js logs to Graylog
warning It is best to use the
graylog2package unless Winston is already part of your project. If that is the case, you can replace it withwinston-gelf.
To install the Winston GELF package, run:
npm install winston-gelf
If Winston is not already in your project, you can add it with:
npm install winston
Here is a basic setup:
const winston = require('winston');
const winstonGelf = require('winston-gelf');
const process = require('process');
const logger = winston.createLogger({
transports: [
new winston.transports.Console(),
new winstonGelf({
// Check all gelfPro options here: https://www.npmjs.com/package/gelf-pro
gelfPro: {
fields: {
env: process.env.NODE_ENV || 'development'
},
adapterName: 'udp',
adapterOptions: {
host: '<XXXXXX>.stackhero-network.com', // Replace with your Graylog domain
port: 12201,
}
}
})
]
});
// Example of an informational log
logger.info('This is a log information');
// Example of an error log
try {
throw Error('This is an example error');
}
catch(error) {
logger.warn({ message: 'Error triggered', error });
}
Do not forget to configure your Graylog input (details below).
Configuring the Graylog input
On the Graylog interface, navigate to System/Inputs, create a new input of type "GELF UDP," and click on "Launch new input." In the modal that appears, check "Global," add a title, and confirm without modifying any other settings.
That is all there is to it! Your Graylog is now set up to receive logs from your Node.js application.
To enhance security, consider filtering the IPs allowed to send data to port 12201. You can do this by going to the Stackhero dashboard, selecting your Graylog service, and configuring the "Firewall" to allow only your IPs.