tracebin 0.0.7

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.
Files changed (42) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +12 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +5 -0
  5. data/CODE_OF_CONDUCT.md +74 -0
  6. data/Gemfile +4 -0
  7. data/LICENSE.txt +21 -0
  8. data/README.md +42 -0
  9. data/Rakefile +6 -0
  10. data/bin/console +14 -0
  11. data/bin/setup +8 -0
  12. data/dump.rdb +0 -0
  13. data/lib/vizsla/agent.rb +87 -0
  14. data/lib/vizsla/background_job_instrumentation/active_job.rb +14 -0
  15. data/lib/vizsla/background_job_instrumentation/resque.rb +37 -0
  16. data/lib/vizsla/background_job_instrumentation/sidekiq.rb +19 -0
  17. data/lib/vizsla/background_job_instrumentation.rb +34 -0
  18. data/lib/vizsla/background_timer.rb +9 -0
  19. data/lib/vizsla/config.rb +21 -0
  20. data/lib/vizsla/events.rb +67 -0
  21. data/lib/vizsla/health_monitor.rb +24 -0
  22. data/lib/vizsla/helpers.rb +7 -0
  23. data/lib/vizsla/logger.rb +55 -0
  24. data/lib/vizsla/middleware.rb +51 -0
  25. data/lib/vizsla/patches/action_view_layout.rb +34 -0
  26. data/lib/vizsla/patches/mysql2.rb +22 -0
  27. data/lib/vizsla/patches/postgres.rb +42 -0
  28. data/lib/vizsla/patches/sidekiq_health.rb +27 -0
  29. data/lib/vizsla/patches/sinatra.rb +21 -0
  30. data/lib/vizsla/patches.rb +44 -0
  31. data/lib/vizsla/puppet_master.rb +17 -0
  32. data/lib/vizsla/recorder.rb +43 -0
  33. data/lib/vizsla/reporter.rb +74 -0
  34. data/lib/vizsla/storage.rb +30 -0
  35. data/lib/vizsla/subscribers.rb +172 -0
  36. data/lib/vizsla/system_health_sample.rb +187 -0
  37. data/lib/vizsla/timer.rb +60 -0
  38. data/lib/vizsla/version.rb +3 -0
  39. data/lib/vizsla/worker_process_monitor.rb +25 -0
  40. data/lib/vizsla.rb +17 -0
  41. data/vizsla.gemspec +29 -0
  42. metadata +154 -0
@@ -0,0 +1,60 @@
1
+ require 'vizsla/recorder'
2
+ require 'vizsla/helpers'
3
+
4
+
5
+ module Vizsla
6
+ class Timer
7
+ include ::Vizsla::Helpers
8
+
9
+ attr_accessor :transaction_name
10
+ attr_reader :events
11
+
12
+ def initialize(transaction_name = nil)
13
+ @transaction_name = transaction_name
14
+ @start_time = nil
15
+ @stop_time = nil
16
+ end
17
+
18
+ def start!
19
+ @start_time = Time.now
20
+ Recorder.start_recording
21
+ end
22
+
23
+ def stop!
24
+ collect_events
25
+ Recorder.stop_recording
26
+ @stop_time = Time.now
27
+ end
28
+
29
+ def payload
30
+ {
31
+ type: :cycle_transaction,
32
+
33
+ data: {
34
+ transaction_type: transaction_type,
35
+ name: @transaction_name,
36
+
37
+ start: @start_time,
38
+ stop: @stop_time,
39
+ duration: duration,
40
+
41
+ events: @events
42
+ }
43
+ }
44
+ end
45
+
46
+ def duration
47
+ to_milliseconds @stop_time - @start_time
48
+ end
49
+
50
+ def transaction_type
51
+ 'request_response'
52
+ end
53
+
54
+ private
55
+
56
+ def collect_events
57
+ @events = Recorder.events
58
+ end
59
+ end
60
+ end
@@ -0,0 +1,3 @@
1
+ module Vizsla
2
+ VERSION = "0.0.7"
3
+ end
@@ -0,0 +1,25 @@
1
+ require 'vizsla/patches'
2
+ require 'vizsla/puppet_master'
3
+
4
+ module Vizsla
5
+ class WorkerProcessMonitor
6
+ class << self
7
+ def start
8
+ sidekiq_health_patch
9
+
10
+ self
11
+ end
12
+
13
+ def stop!
14
+ end
15
+
16
+ def sidekiq_health_patch
17
+ return unless defined? ::Sidekiq
18
+
19
+ ::Vizsla::Patches.patch_sidekiq_health do |health_data|
20
+ ::Vizsla::PuppetMaster.new(health_data, logger: ::Sidekiq::Logging.logger).process
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end
data/lib/vizsla.rb ADDED
@@ -0,0 +1,17 @@
1
+ require 'vizsla/version'
2
+ require 'vizsla/config'
3
+ require 'vizsla/subscribers'
4
+ require 'vizsla/health_monitor'
5
+ require 'vizsla/worker_process_monitor'
6
+ require 'vizsla/agent'
7
+ require 'vizsla/middleware'
8
+
9
+ if defined?(::Rails) && defined?(::Rails::Railtie)
10
+ module Vizsla
11
+ class Railtie < Rails::Railtie
12
+ initializer 'vizsla.start' do |app|
13
+ app.middleware.use Vizsla::Middleware
14
+ end
15
+ end
16
+ end
17
+ end
data/vizsla.gemspec ADDED
@@ -0,0 +1,29 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'vizsla/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "tracebin"
8
+ spec.version = Vizsla::VERSION
9
+ spec.authors = ["Tyler Guillen"]
10
+ spec.email = ["tyguillen@gmail.com"]
11
+
12
+ spec.summary = "Easy performance analytics for your Rack/Rails app! Formerly known as 'vizsla.'"
13
+ spec.homepage = "https://google.com"
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
17
+ f.match(%r{^(test|spec|features)/})
18
+ end
19
+ spec.bindir = "exe"
20
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
21
+ spec.require_paths = ["lib"]
22
+
23
+ spec.add_dependency "concurrent-ruby", "~> 1.0"
24
+
25
+ spec.add_development_dependency "bundler", "~> 1.14"
26
+ spec.add_development_dependency "rake", "~> 10.0"
27
+ spec.add_development_dependency "rspec", "~> 3.0"
28
+ spec.add_development_dependency 'pry', '~> 0.10'
29
+ end
metadata ADDED
@@ -0,0 +1,154 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: tracebin
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.7
5
+ platform: ruby
6
+ authors:
7
+ - Tyler Guillen
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2017-04-22 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: concurrent-ruby
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: bundler
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '1.14'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '1.14'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rake
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '10.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '10.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '3.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '3.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: pry
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '0.10'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '0.10'
83
+ description:
84
+ email:
85
+ - tyguillen@gmail.com
86
+ executables: []
87
+ extensions: []
88
+ extra_rdoc_files: []
89
+ files:
90
+ - ".gitignore"
91
+ - ".rspec"
92
+ - ".travis.yml"
93
+ - CODE_OF_CONDUCT.md
94
+ - Gemfile
95
+ - LICENSE.txt
96
+ - README.md
97
+ - Rakefile
98
+ - bin/console
99
+ - bin/setup
100
+ - dump.rdb
101
+ - lib/vizsla.rb
102
+ - lib/vizsla/agent.rb
103
+ - lib/vizsla/background_job_instrumentation.rb
104
+ - lib/vizsla/background_job_instrumentation/active_job.rb
105
+ - lib/vizsla/background_job_instrumentation/resque.rb
106
+ - lib/vizsla/background_job_instrumentation/sidekiq.rb
107
+ - lib/vizsla/background_timer.rb
108
+ - lib/vizsla/config.rb
109
+ - lib/vizsla/events.rb
110
+ - lib/vizsla/health_monitor.rb
111
+ - lib/vizsla/helpers.rb
112
+ - lib/vizsla/logger.rb
113
+ - lib/vizsla/middleware.rb
114
+ - lib/vizsla/patches.rb
115
+ - lib/vizsla/patches/action_view_layout.rb
116
+ - lib/vizsla/patches/mysql2.rb
117
+ - lib/vizsla/patches/postgres.rb
118
+ - lib/vizsla/patches/sidekiq_health.rb
119
+ - lib/vizsla/patches/sinatra.rb
120
+ - lib/vizsla/puppet_master.rb
121
+ - lib/vizsla/recorder.rb
122
+ - lib/vizsla/reporter.rb
123
+ - lib/vizsla/storage.rb
124
+ - lib/vizsla/subscribers.rb
125
+ - lib/vizsla/system_health_sample.rb
126
+ - lib/vizsla/timer.rb
127
+ - lib/vizsla/version.rb
128
+ - lib/vizsla/worker_process_monitor.rb
129
+ - vizsla.gemspec
130
+ homepage: https://google.com
131
+ licenses:
132
+ - MIT
133
+ metadata: {}
134
+ post_install_message:
135
+ rdoc_options: []
136
+ require_paths:
137
+ - lib
138
+ required_ruby_version: !ruby/object:Gem::Requirement
139
+ requirements:
140
+ - - ">="
141
+ - !ruby/object:Gem::Version
142
+ version: '0'
143
+ required_rubygems_version: !ruby/object:Gem::Requirement
144
+ requirements:
145
+ - - ">="
146
+ - !ruby/object:Gem::Version
147
+ version: '0'
148
+ requirements: []
149
+ rubyforge_project:
150
+ rubygems_version: 2.6.11
151
+ signing_key:
152
+ specification_version: 4
153
+ summary: Easy performance analytics for your Rack/Rails app! Formerly known as 'vizsla.'
154
+ test_files: []