Published on July 18, 2022

Track your NodeJs cron jobs

Track your NodeJs cron jobs

When setting up cron jobs in NodeJs, it is usually crucial to keep track of their execution and whether they have been executed successfully or not. Sometimes, a minor failure in a cronjob can cause your NodeJs application to stop working correctly. LogSnag makes it easy to track your cron jobs and their execution status all in real-time, and it works seamlessly with your NodeJs code.


Setting up your account

Setting up LogSnag with NodeJs is very simple!

  1. Create a free LogSnag account.
  2. Create a new project on your dashboard.
  3. Copy your API token from the settings page.

NodeJs code snippets

Once your LogSnag account is set up, you can use the following code snippets to track your cron jobs. Just replace the YOUR_API_TOKEN with your LogSnag API token and update your project name.

Using NodeJs with Axios
const axios = require('axios');
let data = JSON.stringify({
"project": "my-saas",
"channel": "cronjobs",
"event": "Cronjob Started",
"description": "job: email-notifications",
"icon": "⏰",
"notify": true
});

let config = {
method: 'post',
maxBodyLength: Infinity,
url: 'https://api.logsnag.com/v1/log',
headers: {
'Content-Type': 'application/json',
'Authorization': 'Bearer YOUR_API_TOKEN'
},
data : data
};

axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});
Using NodeJs with Native
var https = require('follow-redirects').https;
var fs = require('fs');

var options = {
'method': 'POST',
'hostname': 'api.logsnag.com',
'path': '/v1/log',
'headers': {
'Content-Type': 'application/json',
'Authorization': 'Bearer YOUR_API_TOKEN'
},
'maxRedirects': 20
};

var req = https.request(options, function (res) {
var chunks = [];

res.on("data", function (chunk) {
chunks.push(chunk);
});

res.on("end", function (chunk) {
var body = Buffer.concat(chunks);
console.log(body.toString());
});

res.on("error", function (error) {
console.error(error);
});
});

var postData = JSON.stringify({
"project": "my-saas",
"channel": "cronjobs",
"event": "Cronjob Started",
"description": "job: email-notifications",
"icon": "⏰",
"notify": true
});

req.write(postData);

req.end();
Using NodeJs with Request
var request = require('request');
var options = {
'method': 'POST',
'url': 'https://api.logsnag.com/v1/log',
'headers': {
'Content-Type': 'application/json',
'Authorization': 'Bearer YOUR_API_TOKEN'
},
body: JSON.stringify({
"project": "my-saas",
"channel": "cronjobs",
"event": "Cronjob Started",
"description": "job: email-notifications",
"icon": "⏰",
"notify": true
})

};
request(options, function (error, response) {
if (error) throw new Error(error);
console.log(response.body);
});
Using NodeJs with Unirest
var unirest = require('unirest');
var req = unirest('POST', 'https://api.logsnag.com/v1/log')
.headers({
'Content-Type': 'application/json',
'Authorization': 'Bearer YOUR_API_TOKEN'
})
.send(JSON.stringify({
"project": "my-saas",
"channel": "cronjobs",
"event": "Cronjob Started",
"description": "job: email-notifications",
"icon": "⏰",
"notify": true
}))
.end(function (res) {
if (res.error) throw new Error(res.error);
console.log(res.raw_body);
});

NodeJs integration details

LogSnag is an easy-to-use event tracking tool that allows you to track any event within your NodeJs application. One of the most common use cases for LogSnag is tracking cron jobs as they are being executed. With LogSnag, you can receive real-time push notifications on your desktop and mobile devices whenever a new cronjob is executed. In addition, you can create simple charts and filter through your data to help you better understand how your NodeJs application is performing.

Other use-cases for LogSnag

  1. Monitor your CI/CD build status for your NodeJs application
  2. Monitor your CPU usage in your NodeJs application
  3. Monitor when database goes down in your NodeJs application
  4. Monitor high disk usage in your NodeJs application
  5. Monitor when a user changes their email address in your NodeJs application
  6. Monitor failed logins in your NodeJs application
  7. Monitor failed payments for your NodeJs application
  8. Monitor memory usage in your NodeJs application
  9. Monitor MySQL downtime in your NodeJs application
  10. Monitor when a new feature is used in your NodeJs application
  11. Monitor your Postgres downtime in your NodeJs application
  12. Monitor Redis downtime in your NodeJs application
  13. Monitor suspicious activity in your NodeJs application
  14. Monitor when a user exceeds the usage limit for your NodeJs service
  15. Monitor when a user is being rate limited in your NodeJs application
  16. Get a notification when your NodeJs code is done executing
  17. Send push notifications to your phone or desktop using NodeJs
  18. Track canceled subscriptions in your NodeJs application
  19. Track when a file is uploaded to your NodeJs application
  20. Track when a form is submitted to your NodeJs application
  21. Track payment events via NodeJs
  22. Track user sign in events in NodeJs
  23. Track user signup events via NodeJs
  24. Track waitlist signup events via NodeJs
View all common use-cases with NodeJs