Skip to content

Log4j appender for sending log4j events to a Redis server for easy integration with Logstash.

License

Notifications You must be signed in to change notification settings

bolcom/log4j-redis-appender

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

log4j-redis-appender

Log4j appender for pushing log4j events to a Redis list, for easy integration with Logstash.

It also protects the JVM against OOM's from too many buffered events. And it exposes metrics about its throughput and data loss.

The code is based from @ryantenney's work, which in turn was derived from @pavlobaron's log4j2redis work.

The main differences compared to Ryan's great work:

  • it drops events to protect the JVM against OOM's
  • it detects Redis OOM's
  • it keeps metrics (about throughput + drops),

This appender works great with log4j-jsonevent-layout to transform all events into JSON documents, for easy processing by Logstash.

Configuration

This appender pushes log4j events to a Redis list. Here is an example XML configuration:

   <appender name="JSON_REDIS" class="com.bol.log4j.FailoverRedisAppender">
      <param name="endpoints" value="server1:6379,server2:6379" />
      <param name="alwaysBatch" value="false" />
      <param name="batchSize" value="50" />
      <param name="flushInterval" value="1000" />
      <param name="queueSize" value="5000" />
      <param name="registerMBean" value="true" />
      <param name="key" value="logstash.log4j" />
      <param name="Threshold" value="DEBUG"/>
      <layout class="net.logstash.log4j.JSONEventLayout">
         <param name="userfields" value="application:xyz,role:xyz-app"/>
      </layout>
   </appender>

Where:

  • endpoints (optional) comma separated list of Redis servers in format :. The list is shuffled at startup. When connecting or reconnecting the next server on the list is used.
  • host + port (optional, default: localhost:6379) Hostname/IP and port number of a single Redis server. Use this OR endpoints to configure the Redis server(s) used.
  • key (required) Redis key of the list to RPUSH events to.
  • password (optional) Redis password, if required.
  • alwaysBatch (optional, default: true) whether to wait for a full batch. If true, will only send once there are batchSize events enqueued.
  • batchSize (optional, default: 100) the number of events to send in a single Redis RPUSH command.
  • flushInterval (optional, default: 500) the period in milliseconds between flush attempts. If events are flushed depends on the 'alwaysBatch' setting and the number of events in the buffer.
  • queueSize (optional, default: 5000) the maximum number of events the appender holds in memory, awaiting flush. If flushing is not possible, or is too slow the queue will slowly fill up. When the queue is full, new events will be dropped to protect the JVM.
  • purgeOnFailure (optional, default: true) whether to purge/drop events if Redis responds to a RPUSH with an OOM error. If 'false' the appender will attempt to send the events to Redis. If that keeps failing the queue will slowly fill up and new events will be dropped.
  • registerMBean (optional, default: true) whether to expose the appender's metrics as MBean.

Metrics

When the appender's MBean is registered (see registerMBean configuration) the following metrics are available under MBean "com.bol.log4j:type=FailoverRedisAppender":

  • eventCounter: (counter) number of events received by the appender and put in the queue. Configuration queueSize controls the the maximum number of events this queue can hold.
  • eventsDroppedInQueueing: (counter) number of events that got dropped, because the queue was full. You get a full queue if Redis is full or your application is emitting events faster than can be pushed to Redis. You can increase queueSize or rise the log4j threshold to ignore events based on their level (DEBUG can be noisy).
  • eventsDroppedInPush: (counter) number of events that got dropped, because the Redis' memory is full and responds to RPUSH commands with an OOM error.
  • connectCounter: (counter)number of connects made to the Redis server(s).
  • connectFailures: (counter) number of connect attempts that failed.
  • batchPurges: (counter) number of times the purge queue got purged. This only happens if purgeOnFailure is set to true.
  • eventsPushed: (counter) number of events succesfully pushed to Redis.
  • eventQueueSize: (gauge) number of events in the queue. When reading this attribute you get a sampled value. Use this to get a feel about the average number of queued events. When this gets above 50% of queueSize you may want to investigate a slow Redis server or silly amounts of events being emitted by your application.

JCollectd configuration

Use Jcollectd in your JVM to periodically flush MBean metrics to collectd or Diamond's JCollectdCollector.

Jcollectd XML config for this appender:

<jcollectd-config>
  <mbeans name="log4j">
    <mbean name="com.bol.log4j:type=FailoverRedisAppender" alias="RedisAppender">
      <attribute name="ConnectCounter" type="counter"/>
      <attribute name="ConnectFailures" type="counter"/>
      <attribute name="EventCounter" type="counter"/>
      <attribute name="EventsPushed" type="counter"/>
      <attribute name="EventsDroppedInPush" type="counter"/>
      <attribute name="EventsDroppedInQueueing" type="counter"/>
      <attribute name="EventQueueSize" />
      <attribute name="BatchPurges" type="counter"/>
    </mbean>
  </mbeans>
</jcollectd-config>

Future plans

Some ideas for future improvements:

  • add sampling or a per-minute quota of events
  • got ideas? let me know

Contributors

Contribution

Feel free to create an issue or submit a pull request.

License

Published under Apache Software License 2.0, see LICENSE

Acknowledgement

This program was originally developed by bol.com and published as Open Source on github.

About

Log4j appender for sending log4j events to a Redis server for easy integration with Logstash.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%