summaryrefslogtreecommitdiff
path: root/config/initializers
diff options
context:
space:
mode:
authorStan Hu <stanhu@gmail.com>2017-07-17 15:54:13 -0700
committerStan Hu <stanhu@gmail.com>2017-07-18 09:49:21 -0700
commite2b1c16ade09c0afde11d8b39bac9f1974c9b057 (patch)
tree8afe70ff4df1fcf3ba66d4f9fc4feacc310d76a7 /config/initializers
parent79dcaec6eddad2e5d370f9c4ecf2de24ff7980e8 (diff)
downloadgitlab-ce-e2b1c16ade09c0afde11d8b39bac9f1974c9b057.tar.gz
Add structured logging for Rails processessh-structured-logging
This introduces JSON logging for Rails views saved to a file called `development_json.log`, `production_json.log`, etc. For example, instead of this unparsable log: ``` Started GET "/" for 127.0.0.1 at 2012-03-10 14:28:14 +0100 Processing by HomeController#index as HTML Rendered text template within layouts/application (0.0ms) Rendered layouts/_assets.html.erb (2.0ms) Rendered layouts/_top.html.erb (2.6ms) Rendered layouts/_about.html.erb (0.3ms) Rendered layouts/_google_analytics.html.erb (0.4ms) Completed 200 OK in 79ms (Views: 78.8ms | ActiveRecord: 0.0ms) ``` We get a single line with this: ``` {"method":"GET","path":"/,"format":"html","controller":"HomeController","action":"index","status":200,"duration":79,"view":78.8,"db":0.0,"location":"http://localhost/","time":"2017-07-18 09:35:17 -0700"} ``` Part of #20060
Diffstat (limited to 'config/initializers')
-rw-r--r--config/initializers/lograge.rb21
1 files changed, 21 insertions, 0 deletions
diff --git a/config/initializers/lograge.rb b/config/initializers/lograge.rb
new file mode 100644
index 00000000000..14902316240
--- /dev/null
+++ b/config/initializers/lograge.rb
@@ -0,0 +1,21 @@
+# Only use Lograge for Rails
+unless Sidekiq.server?
+ filename = File.join(Rails.root, 'log', "#{Rails.env}_json.log")
+
+ Rails.application.configure do
+ config.lograge.enabled = true
+ # Store the lograge JSON files in a separate file
+ config.lograge.keep_original_rails_log = true
+ # Don't use the Logstash formatter since this requires logstash-event, an
+ # unmaintained gem that monkey patches `Time`
+ config.lograge.formatter = Lograge::Formatters::Json.new
+ config.lograge.logger = ActiveSupport::Logger.new(filename)
+ # Add request parameters to log output
+ config.lograge.custom_options = lambda do |event|
+ {
+ time: event.time,
+ params: event.payload[:params].except(%w(controller action format))
+ }
+ end
+ end
+end