logjam_agent 0.0.4 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/lib/logjam_agent/rack/logger.rb +52 -0
- data/lib/logjam_agent/railtie.rb +36 -0
- data/lib/logjam_agent/request.rb +1 -1
- data/lib/logjam_agent/version.rb +1 -1
- metadata +6 -4
@@ -0,0 +1,52 @@
|
|
1
|
+
module LogjamAgent
|
2
|
+
module Rack
|
3
|
+
class Logger < ActiveSupport::LogSubscriber
|
4
|
+
def initialize(app)
|
5
|
+
@app = app
|
6
|
+
@hostname = Socket.gethostname
|
7
|
+
end
|
8
|
+
|
9
|
+
def call(env)
|
10
|
+
start_time = Time.now
|
11
|
+
before_dispatch(env, start_time)
|
12
|
+
result = @app.call(env)
|
13
|
+
ensure
|
14
|
+
run_time = Time.now - start_time
|
15
|
+
after_dispatch(env, result, run_time*1000)
|
16
|
+
end
|
17
|
+
|
18
|
+
protected
|
19
|
+
|
20
|
+
def before_dispatch(env, start_time)
|
21
|
+
TimeBandits.reset
|
22
|
+
|
23
|
+
Thread.current[:time_bandits_completed_info] = nil
|
24
|
+
|
25
|
+
request = ActionDispatch::Request.new(env)
|
26
|
+
path = request.filtered_path
|
27
|
+
|
28
|
+
Rails.logger.request.fields.merge!(:started_at => start_time, :ip => request.ip, :host => @hostname)
|
29
|
+
|
30
|
+
info "\n\nStarted #{request.request_method} \"#{path}\" for #{request.ip} at #{start_time.to_default_s}"
|
31
|
+
end
|
32
|
+
|
33
|
+
def after_dispatch(env, result, run_time_ms)
|
34
|
+
status = result ? result.first : 500
|
35
|
+
duration, additions, view_time, action = Thread.current[:time_bandits_completed_info]
|
36
|
+
|
37
|
+
basic_request_info = {:total_time => run_time_ms, :code => status, :action => action, :view_time => view_time || 0.0}
|
38
|
+
|
39
|
+
message = "Completed #{status} #{::Rack::Utils::HTTP_STATUS_CODES[status]} in %.1fms" % run_time_ms
|
40
|
+
message << " (#{additions.join(' | ')})" unless additions.blank?
|
41
|
+
info message
|
42
|
+
|
43
|
+
ActiveSupport::LogSubscriber.flush_all!
|
44
|
+
|
45
|
+
Rails.logger.request.fields.merge!(basic_request_info)
|
46
|
+
|
47
|
+
env["time_bandits.metrics"] = TimeBandits.metrics
|
48
|
+
end
|
49
|
+
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
require 'logjam_agent'
|
2
|
+
module LogjamAgent
|
3
|
+
class Railtie < Rails::Railtie
|
4
|
+
|
5
|
+
initializer "initialize_logjam_agent_logger", :before => :initialize_logger do |app|
|
6
|
+
Rails.logger ||= app.config.logger ||
|
7
|
+
begin
|
8
|
+
path = app.config.paths.log.to_a.first
|
9
|
+
logger = LogjamAgent::BufferedLogger.new(path)
|
10
|
+
logger.level = ActiveSupport::BufferedLogger.const_get(app.config.log_level.to_s.upcase)
|
11
|
+
logger.auto_flushing = false if Rails.env.production?
|
12
|
+
logger
|
13
|
+
rescue StandardError => e
|
14
|
+
logger = LogjamAgent::BufferedLogger.new(STDERR)
|
15
|
+
logger.level = ActiveSupport::BufferedLogger::WARN
|
16
|
+
logger.warn(
|
17
|
+
"Logging Error: Unable to access log file. Please ensure that #{path} exists and is writable. " +
|
18
|
+
"The log level has been raised to WARN and the output directed to STDERR until the problem is fixed."
|
19
|
+
)
|
20
|
+
logger
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
initializer "logjam_agent", :after => "time_bandits" do |app|
|
25
|
+
app.config.middleware.swap("TimeBandits::Rack::Logger", "LogjamAgent::Rack::Logger")
|
26
|
+
app.config.middleware.insert_before("LogjamAgent::Rack::Logger", "LogjamAgent::Middleware")
|
27
|
+
|
28
|
+
ActiveSupport.on_load(:action_controller) do
|
29
|
+
require 'logjam_agent/middleware.rb'
|
30
|
+
require 'logjam_agent/rack/logger.rb'
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
data/lib/logjam_agent/request.rb
CHANGED
data/lib/logjam_agent/version.rb
CHANGED
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: logjam_agent
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
hash:
|
4
|
+
hash: 27
|
5
5
|
prerelease:
|
6
6
|
segments:
|
7
7
|
- 0
|
8
|
+
- 1
|
8
9
|
- 0
|
9
|
-
|
10
|
-
version: 0.0.4
|
10
|
+
version: 0.1.0
|
11
11
|
platform: ruby
|
12
12
|
authors:
|
13
13
|
- Stefan Kaes
|
@@ -15,7 +15,7 @@ autorequire:
|
|
15
15
|
bindir: bin
|
16
16
|
cert_chain: []
|
17
17
|
|
18
|
-
date: 2011-
|
18
|
+
date: 2011-09-04 00:00:00 +02:00
|
19
19
|
default_executable:
|
20
20
|
dependencies:
|
21
21
|
- !ruby/object:Gem::Dependency
|
@@ -68,6 +68,8 @@ files:
|
|
68
68
|
- lib/logjam_agent/buffered_logger.rb
|
69
69
|
- lib/logjam_agent/forwarders.rb
|
70
70
|
- lib/logjam_agent/middleware.rb
|
71
|
+
- lib/logjam_agent/rack/logger.rb
|
72
|
+
- lib/logjam_agent/railtie.rb
|
71
73
|
- lib/logjam_agent/request.rb
|
72
74
|
- lib/logjam_agent/syslog_like_formatter.rb
|
73
75
|
- lib/logjam_agent/version.rb
|