Messaging, interoperability and log aggregation - a new framework

By Tomas Doran (‎t0m‎) from drinkers.pm
Date: Saturday, 24 November 2012 14:10
Duration: 50 minutes
Target audience: Intermediate
Language: English
Tags: anyevent elasticsearch logstash perl rabbitmq sysadmin zeromq


In this talk, I will talk about why log files are horrible, logging log lines, and more structured performance metrics from large scale production applications as well as building reliable, scaleable and flexible large scale software systems in multiple languages.

Why (almost) all log formats are horrible will be explained, and why JSON is a good solution for logging will be discussed, along with a number of message queuing, middleware and network transport technologies, including STOMP, AMQP and ZeroMQ.

The Message::Passing framework will be introduced, along with the logstash.net project which the perl code is interoperable with. These are pluggable frameworks in ruby/java/jruby and perl with pre-written sets of inputs, filters and outputs for many many different systems, message formats and transports.

They were initially designed to be aggregators and filters of data for logging. However they are flexible enough to be used as part of your messaging middleware, or even as a replacement for centralised message queuing systems.

You can have your cake and eat it too - an architecture which is flexible, extensible, scaleable and distributed. Build discrete, loosely coupled components which just pass messages to each other easily.

Integrate and interoperate with your existing code and code bases easily, consume from or publish to any existing message queue, logging or performance metrics system you have installed.

Simple examples using common input and output classes will be demonstrated using the framework, as will easily adding your own custom filters. A number of common messaging middleware patterns will be shown to be trivial to implement.

Some higher level use-cases will also be explored, demonstrating log indexing in ElasticSearch and how to build a responsive platform API using webhooks.

Interoperability is also an important goal for messaging middleware. The logstash.net project will be highlighted and we'll discuss crossing the single language barrier, allowing us to have full integration between java, ruby and perl components, and to easily write bindings into libraries we want to reuse in any of those languages.


Attended by: Tom Molesworth, Aaron Crane (‎arc‎), Mark Norman Francis, Tomasz Czepiel (‎tjmc‎), Mohammad Anwar (‎manwar‎), Jess Robinson (‎castaway‎), James Aitken (‎LoonyPandora‎), Michele Beltrame (‎arthas‎), Pete Barlow, Dominic Humphries (‎djh‎), Mike Eve, Jonas Weismueller (‎MrRagga‎), cjbradford, Anthony Lucas (‎hor|zon‎), Nigel Metheringham (‎nigelm‎), Alexandru Strajeriu (‎Deluxaran‎), Istvan Gal, osfameron, Russell Wheeler, Mircea Patachi, Ben Rogers, Diana Donca, Andreea Stanciu, Tudor Constantin, Johnathan Swan, fifi, Michael Woods, M Walker, Diana Nutu, Mirela Iclodean, kevin mulholland (‎moodfarm‎), Andrew Jones, Iain Campbell, Mark Stringer (‎mullet‎), Tamara Kaufler, Pedro Figueiredo (‎pfig‎), Steve Holden, John Harrison (‎JohnGH‎), kevin dawson (‎bowtie‎), Paul Evans (‎LeoNerd‎),

Sponsors

Corporate

antibodyMX

Booking.com

Bytemark Hosting

Eligo Recruitment

Evozon Software

Exonetric

magnum Solutions

Motortrak

Nestoria

Net-A-Porter

Opus VL

Petamem

Shadowcat
      Systems Limited

Community

Enlightened Perl Organisation

Bar design at the bottom of the page