SweetLogger
This little gem solves two issues with rails ActiveSuppot::Logger
when it's
running in a multi-threaded environment.
- It doesn't let log entries for concurrent requests overlap
- Adds a log silencer (for
/assets/
) that works correctly with multiple threads
Installation
Add this line to your application's Gemfile:
gem 'sweet-logger'
Enjoy!
Rack::Lock
By default in the development
environment, Rails adds the Rack::Lock
middleware
so that the rack server will process only one request at a time.
If you need to enable the real multi-threaded processing in the development
environment, add this to your config/application.rb
config.middleware.delete Rack::Lock
Also, you might going to need add the folloing to your config/development.rb
if your
web page makes several requests to your app on a page load
config.eager_load = true
That will prevent race conditions on code-reloads when you make changes to your app code.
Silencer
Our sweet logger comes with a silencer in case you need to remove some of the
entries from leaking into the logs. By default it silences the /assets/
entries.
But if you need to silence anything else, add this to one of your rails initializers
SweetLogger.silence %w[
favicon.io
livereload.js
/something/else
]
NOTE: logger will check if the route included in the current request's path.
Contributing
- Fork it ( https://github.com/MadRabbit/sweet-logger/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request