resque_statsd 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
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: []