npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

lumberjack-protocol

v1.0.7

Published

Node.js implementation of the lumberjack protocol.

Downloads

3,761

Readme

NPM

Build Status Coverage Status Dependency Status devDependency Status

What is it?

This is a node.js implementation of the lumberjack protocol from logstash-forwarder.

At the moment, only the sender-side implementation is complete. This is an excellent way to send encrypted logs from your node.js app to your logstash instance. If you are using bunyan, be sure to check out bunyan-lumberjack.

Contents

Installation

npm install --save lumberjack-protocol

Usage

Create a lumberjack Client; it will connect to the server in the background, automatically reconnect, and queue any messages that you try to send while disconnected:

var lumberjack = require('lumberjack-protocol');
var fs = require('fs');

var connectionOptions = {
    host: "myserver.com",
    port: 5000,
    ca: [fs.readFileSync('./logstash.crt', {encoding: 'utf-8'})]
};

var client = lumberjack.client(connectionOptions, {maxQueueSize: 500});

client.writeDataFrame({"line": "Hello World!"});

API

Full API documentation can be found here.

Caveats

According to the lumberjack specification, the window size is "maximum number of unacknowledged data frames the writer will send before blocking for acks." Node.js doesn't support blocking IO; you might think it would be reasonable to drop messages if the client runs into the window size, but in actual fact the current logstash implementation will only send an ack every windowSizeth data frame. In other words, if windowSize is 10, then logstash will only send an ack every 10th data frame, so when sending to logstash we would very often lose frames right after the 10th frame while waiting (which would be less than ideal.)

An alternative here would be to queue messages while we wait for the ack, and then send all the queued messages in a burst. This introduces a great deal of complexity, however, as we have to deal with queue management. It does offer some advantages in that we can be selective in how we drop messages (if the queue gets full, for example, we can purge all the debug and info level events from the queue when it comes time to drop messages, for example, meaning that the error messages will have a higher likelihood of getting through.)

The approach taken here is less nuaced - we'll send up to ten times the windowSize to the receiver before waiting for an ack. If we don't get an ack, we'll start dropping messages. You can specify a allowDrop(data) function that will prevent messages from being dropped if there are certain types of messages you want to ensure get through (errors, for example.)

Troubleshooting

Hostname/IP doesn't match certificate's altnames

  • If you are connecting to a server using a hostname, the hostname must match either the subject's CN in the certificate, or one of the certificate's subjectAltNames.

  • If you are connecting with an IP address, the IP address must be listed in the certificate's subjectAltNames. Note that node.js will not check to see if the IP matches the subject CN.

  • If you are using node >=0.11.x, you can use checkServerIdentity:

      var lj = lumberjack.client({
          checkServerIdentity: function (host, cert) {
              return cert.subject.cn == "expectedservername.com";
          },
          ...
      });
  • If you're doing testing, you can do this the very insecure way, but note this is not secure:

      var lj = lumberjack.client({
          rejectUnauthorized: false,
          ...
      });
        

    You may also see suggestions to set an enviroment variable:

    process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
      

    which is effectively the same thing. Both of these options will bypass certificate checks which will make it easy for a third party to intercept your traffic using a man-in-the-middle attack. Do not set these options unless you are very sure you know what you are doing.

Error: self signed certificate, code: DEPTH_ZERO_SELF_SIGNED_CERT

If you're using a self-signed certificate, be sure you are passing it in the ca parameter to the connectOptions. You can fetch the certificate your server is using with openssl:

openssl s_client -showcerts -connect myserver.com:5000 -tls1