Wildcloud - Logger

Logging library extracted from Wildcloud project.

Status

More work needed.

Example

The library is distributed as a gem

gem install wildcloud-logger

Or if you use Bundler (and you should!)

gem 'wildcloud-logger', :require => 'wildcloud/logger'

Now you can create logger instance and give it an application name

@logger = Wildcloud::Logger::Logger.new
@logger.application = 'MyCoolApplication'

Your logger is ready to be used, however all messages will be lost.

To process messages you got to add some middleware.

Most common example during the development is to output messages to console (stdout)

require 'wildcloud/logger/middleware/console'
@logger.add(Wildcloud::Logger::Middleware::Console)

More complex example is to publish to some AMQP exchange

require 'wildcloud/logger/middleware/amqp'
@topic = AMQP::Channel.new(AMQP.connect()).topic('<<some_exchange_name>>')
@logger.add(Wildcloud::Logger::Middleware::Amqp, :exchange => @topic, :routing_key => '<<some_routing_key>>')

It's very simple to write new middleware.

Middleware

  • Console - output to $stdout
  • Json - encodes message into JSON (JSON.dump(message)) and puts it into the messages as :json_encoded key
  • Amqp - publishes message to AMQP exchange, by default takes :json_encoded key

Design

Logger is inspired by Rack architecture. Wildcloud::Logger::Logger serves as entry point for accepting logging messages, which are then passed to middleware for further processing.

Logger allows adding custom logging levels and modifying the default ones. Levels are specified as Ruby symbols with specific score that is used to compare importance. By default Logger provides these levels:

    { :debug => 10, :info => 20, :warn => 30, :error => 40, :fatal => 50 }

License

Project is licensed under the terms of the Apache 2 license.