resque_statsd 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/.gitignore ADDED
@@ -0,0 +1,4 @@
1
+ .bundle/
2
+ doc/
3
+ pkg
4
+ nbproject
data/.rvmrc ADDED
@@ -0,0 +1 @@
1
+ rvm ruby-1.9.3-p194@resque-statsd --create
data/Gemfile ADDED
@@ -0,0 +1,8 @@
1
+ source :rubygems
2
+ gemspec
3
+
4
+ group :test do
5
+ gem "rake"
6
+ gem "mocha"
7
+ gem "rspec"
8
+ end
data/Gemfile.lock ADDED
@@ -0,0 +1,61 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ resque_statsd (0.1.0)
5
+ resque
6
+ statsd
7
+
8
+ GEM
9
+ remote: http://rubygems.org/
10
+ specs:
11
+ bson (1.8.2)
12
+ diff-lcs (1.1.3)
13
+ erubis (2.7.0)
14
+ eventmachine (1.0.0)
15
+ metaclass (0.0.1)
16
+ mocha (0.13.2)
17
+ metaclass (~> 0.0.1)
18
+ mongo (1.8.2)
19
+ bson (~> 1.8.2)
20
+ multi_json (1.5.0)
21
+ rack (1.5.1)
22
+ rack-protection (1.3.2)
23
+ rack
24
+ rake (10.0.3)
25
+ redis (3.0.2)
26
+ redis-namespace (1.2.1)
27
+ redis (~> 3.0.0)
28
+ resque (1.23.0)
29
+ multi_json (~> 1.0)
30
+ redis-namespace (~> 1.0)
31
+ sinatra (>= 0.9.2)
32
+ vegas (~> 0.1.2)
33
+ rspec (2.12.0)
34
+ rspec-core (~> 2.12.0)
35
+ rspec-expectations (~> 2.12.0)
36
+ rspec-mocks (~> 2.12.0)
37
+ rspec-core (2.12.2)
38
+ rspec-expectations (2.12.1)
39
+ diff-lcs (~> 1.1.3)
40
+ rspec-mocks (2.12.2)
41
+ sinatra (1.3.4)
42
+ rack (~> 1.4)
43
+ rack-protection (~> 1.3)
44
+ tilt (~> 1.3, >= 1.3.3)
45
+ statsd (0.5.4)
46
+ erubis (>= 2.6.6)
47
+ eventmachine (>= 0.12.10)
48
+ mongo (>= 1.2.4)
49
+ tilt (1.3.3)
50
+ vegas (0.1.11)
51
+ rack (>= 1.0.0)
52
+
53
+ PLATFORMS
54
+ ruby
55
+
56
+ DEPENDENCIES
57
+ bundler
58
+ mocha
59
+ rake
60
+ resque_statsd!
61
+ rspec
data/Rakefile ADDED
@@ -0,0 +1,15 @@
1
+ require 'bundler'
2
+
3
+ Bundler::GemHelper.install_tasks
4
+
5
+ $LOAD_PATH.unshift 'lib'
6
+
7
+ task :default => :test
8
+
9
+ # Tests
10
+ desc "Run tests"
11
+ task :test do
12
+ Dir['test/*_spec.rb'].each do |f|
13
+ require File.expand_path(f)
14
+ end
15
+ end
data/Readme.md ADDED
@@ -0,0 +1,6 @@
1
+ Resque-Statsd
2
+ ==============
3
+
4
+
5
+ A resque plugin that adds worker statistics to statsd and is comprehensive.
6
+
@@ -0,0 +1,51 @@
1
+ module Resque
2
+ module Plugins
3
+ module Statsd
4
+ DEFAULT_TASKS = {
5
+ :hostname => Proc.new{ @stat_hostname ||= `hostname`.strip},
6
+ :classname => Proc.new {self.class},
7
+ :queuename => Proc.new {|args| @queue}
8
+ }
9
+ def statsd
10
+ $statsd || @statsd_server
11
+ end
12
+
13
+ def statsd=(statsd)
14
+ @statsd_server = statsd
15
+ end
16
+
17
+ # Stuff to hook up to.
18
+ # Probably need to use batch.
19
+ def around_perform_stats(*args)
20
+ start = Time.now
21
+ yield
22
+ time_taken = Time.now - start
23
+ statsd.timing("duration:#{self}", time_taken)
24
+ statsd.increment("total_successful:#{self}")
25
+ statsd.increment("total_successful")
26
+ if extra_stats_key
27
+ Array(extra_stats_key[:around_perform]).each { |item| statsd.timing("duration:#{DEFAULT_TASKS[item].call(args)}", time_taken)}
28
+ end
29
+ end
30
+
31
+ def on_failure_stats(*args)
32
+ statsd.increment("total_resque_failures")
33
+ statsd.increment("total_resque_failures:#{self}")
34
+ end
35
+
36
+ def after_enqueue_stats(*args)
37
+ statsd.increment("total_enqueues")
38
+ statsd.increment("total_enqueues:#{self}")
39
+ end
40
+
41
+ def after_dequeue_stats(*args)
42
+ statsd.increment("total_dequeues")
43
+ statsd.increment("total_dequeues:#{self.class}")
44
+ end
45
+
46
+ def extra_stats_key
47
+ @extra_stats_key ||= {}
48
+ end
49
+ end
50
+ end
51
+ end
@@ -0,0 +1,2 @@
1
+ require 'resque'
2
+ require 'resque/plugins/statsd'
data/lib/version.rb ADDED
@@ -0,0 +1,3 @@
1
+ module ResqueStatsd
2
+ VERSION = '0.1.0'
3
+ end
@@ -0,0 +1,27 @@
1
+ # -*- encoding: utf-8 -*-
2
+ require File.expand_path("../lib/version", __FILE__)
3
+
4
+ Gem::Specification.new do |s|
5
+ s.name = "resque_statsd"
6
+ s.version = ResqueStatsd::VERSION
7
+ s.platform = Gem::Platform::RUBY
8
+ s.authors = ["V Sreekanth"]
9
+ s.email = ["sreeix@gmail.com"]
10
+ s.homepage = "https://github.com/sreeix/resque_statsd"
11
+ s.description = s.summary = %q{Resque plugin that pushes the job statistics to statsd}
12
+
13
+ s.rubyforge_project = "resque_statsd"
14
+
15
+ s.files = `git ls-files`.split("\n")
16
+ s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
17
+ s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
18
+
19
+ s.require_paths = ["lib"]
20
+
21
+ s.add_runtime_dependency(%q<statsd>)
22
+ s.add_runtime_dependency(%q<resque>)
23
+
24
+ s.add_development_dependency('rspec')
25
+ s.add_development_dependency('rake')
26
+ s.add_development_dependency('bundler')
27
+ end
metadata ADDED
@@ -0,0 +1,141 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: resque_statsd
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - V Sreekanth
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2013-02-04 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: statsd
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ! '>='
20
+ - !ruby/object:Gem::Version
21
+ version: '0'
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ! '>='
28
+ - !ruby/object:Gem::Version
29
+ version: '0'
30
+ - !ruby/object:Gem::Dependency
31
+ name: resque
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ type: :runtime
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ! '>='
44
+ - !ruby/object:Gem::Version
45
+ version: '0'
46
+ - !ruby/object:Gem::Dependency
47
+ name: rspec
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ - !ruby/object:Gem::Dependency
63
+ name: rake
64
+ requirement: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ! '>='
68
+ - !ruby/object:Gem::Version
69
+ version: '0'
70
+ type: :development
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ none: false
74
+ requirements:
75
+ - - ! '>='
76
+ - !ruby/object:Gem::Version
77
+ version: '0'
78
+ - !ruby/object:Gem::Dependency
79
+ name: bundler
80
+ requirement: !ruby/object:Gem::Requirement
81
+ none: false
82
+ requirements:
83
+ - - ! '>='
84
+ - !ruby/object:Gem::Version
85
+ version: '0'
86
+ type: :development
87
+ prerelease: false
88
+ version_requirements: !ruby/object:Gem::Requirement
89
+ none: false
90
+ requirements:
91
+ - - ! '>='
92
+ - !ruby/object:Gem::Version
93
+ version: '0'
94
+ description: Resque plugin that pushes the job statistics to statsd
95
+ email:
96
+ - sreeix@gmail.com
97
+ executables: []
98
+ extensions: []
99
+ extra_rdoc_files: []
100
+ files:
101
+ - .gitignore
102
+ - .rvmrc
103
+ - Gemfile
104
+ - Gemfile.lock
105
+ - Rakefile
106
+ - Readme.md
107
+ - lib/resque/plugins/statsd.rb
108
+ - lib/resque_statsd.rb
109
+ - lib/version.rb
110
+ - resque_statsd.gemspec
111
+ homepage: https://github.com/sreeix/resque_statsd
112
+ licenses: []
113
+ post_install_message:
114
+ rdoc_options: []
115
+ require_paths:
116
+ - lib
117
+ required_ruby_version: !ruby/object:Gem::Requirement
118
+ none: false
119
+ requirements:
120
+ - - ! '>='
121
+ - !ruby/object:Gem::Version
122
+ version: '0'
123
+ segments:
124
+ - 0
125
+ hash: 1764238999188188537
126
+ required_rubygems_version: !ruby/object:Gem::Requirement
127
+ none: false
128
+ requirements:
129
+ - - ! '>='
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ segments:
133
+ - 0
134
+ hash: 1764238999188188537
135
+ requirements: []
136
+ rubyforge_project: resque_statsd
137
+ rubygems_version: 1.8.24
138
+ signing_key:
139
+ specification_version: 3
140
+ summary: Resque plugin that pushes the job statistics to statsd
141
+ test_files: []