Skip to content

Latest commit

 

History

History
129 lines (100 loc) · 4.74 KB

README.md

File metadata and controls

129 lines (100 loc) · 4.74 KB

logging-rails

A specialized Railtie for integrating the Logging framework into a Rails application. Per default export ist json and some Application specific information are added:

  • mdc.application : Application Name
  • mdc.session_id : Session Id
  • mdc.user_id : current_user.id (if definded)
  • mdc.params : all params Also a Loglevel "event" has been added with the method 'log_event(action, id, msg, id_type = "", target_name = "")'

Features

The railtie provides only one feature - integration of the Logging framework into your Rails application. But this gives you quite a bit of flexibility to format your log messages and direct them to multiple logging destinations: stdout with colors, a rolling log file, email, or even get a growl notification.

Install

Add the logging-rails railtie gem to your Rails project's Gemfile and run bundle install.

gem 'logging-rails', :require => 'logging/rails'

A generator is included with the railtie that will create a config/logging.rb configuration file for use in your Rails project. Please run this generator before attempting to use the Logging framework.

rails generate logging:install

Usage

Out of the box, the Logging framework is configured to behave in the same way as the standard Rails logger setup. The major exception is that the log file will be rolled daily - gone are the days of 2GB log files on production servers.

The railtie adds a configuration option, log_to, that determines where log messages will be sent. This is an array of appender names (an appender writes log messages to some destination such as a file, STDOUT, syslog, email, etc.). The appender configuration should be set in your environment specific configuration file. For example, in production we would want to log to a file and send emails on error:

config.log_to = %w[file email]

The Logging framework sets the global log level from the log_level configuration item. However, each class can be assigned its own log level. This is very useful when debugging a single controller or model in your Rails application. Consider the example below. The overall log level for the application is set to :info, but the log level for the User model and controller is set to :debug.

config.log_level = :info
Logging.logger['User'].level = :debug
Logging.logger['UserController'].level = :debug

When using the logging railtie, a small display of the current logging configuration will be displayed when Rails is in development mode (environment). A description of the display can be found here.

root  ............................................  *debug      -T
- <Appenders::Stdout:0x806bc058 name="stdout">
- <Appenders::RollingFile:0x806bbc0c name="file">
  ActionController::Base  ........................   debug  +A  -T
  ActiveRecord::Base  ............................   debug  +A  -T
  ActiveSupport::Cache::FileStore  ...............   debug  +A  -T
  ActiveSupport::Dependencies  ...................   debug  +A  -T
  Logging  .......................................    *off  -A  -T
  Rails  .........................................   debug  +A  -T

This is useful for understanding more complex logging configurations. It can be annoying in day-to-day usage. To disable, set the show_log_configuration setting to false in the environment specific configuration file.

config.show_log_configuration = false

Author

Original author: Elliot Winkler

Contributors:

License

The MIT License

Copyright © 2011-2012 by Tim Pease

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the Software), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.