rails-autoscale-resque 1.0.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.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 3ebce6e76c02bf28184ac1aa7c7485eb683876014bbb96fa6fb9484a043d6fae
4
+ data.tar.gz: 49ef4f79c9e5f0321a130d4f6e8af242d808b7b458af73e30a5feed34df8702a
5
+ SHA512:
6
+ metadata.gz: 3c345acf531838db441bd4391f4db3973bc9f05f34c47edd07f8694ceb488458770579ef67b31638c69e3d2687f21f4f49d8370702195cc7007a9d31e754d53d
7
+ data.tar.gz: e19a5b314756d03d496bf0e7a16851c96baea97d710e107bf4d32a7f78cc7c520746099ab1f768b43716ad4c2d9dacb3ec01c2a286313746e6d2c7320357b599
data/Gemfile ADDED
@@ -0,0 +1,7 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem "rails-autoscale-core", path: "../rails-autoscale-core"
6
+ gem "minitest"
7
+ gem "rake"
data/Gemfile.lock ADDED
@@ -0,0 +1,54 @@
1
+ PATH
2
+ remote: ../rails-autoscale-core
3
+ specs:
4
+ rails-autoscale-core (1.0.0)
5
+
6
+ PATH
7
+ remote: .
8
+ specs:
9
+ rails-autoscale-resque (1.0.0)
10
+ rails-autoscale-core
11
+ resque (>= 2.0)
12
+
13
+ GEM
14
+ remote: https://rubygems.org/
15
+ specs:
16
+ minitest (5.15.0)
17
+ mono_logger (1.1.1)
18
+ multi_json (1.15.0)
19
+ mustermann (2.0.2)
20
+ ruby2_keywords (~> 0.0.1)
21
+ rack (2.2.4)
22
+ rack-protection (2.2.2)
23
+ rack
24
+ rake (13.0.6)
25
+ redis (4.7.1)
26
+ redis-namespace (1.9.0)
27
+ redis (>= 4)
28
+ resque (2.2.1)
29
+ mono_logger (~> 1.0)
30
+ multi_json (~> 1.0)
31
+ redis-namespace (~> 1.6)
32
+ sinatra (>= 0.9.2)
33
+ ruby2_keywords (0.0.5)
34
+ sinatra (2.2.2)
35
+ mustermann (~> 2.0)
36
+ rack (~> 2.2)
37
+ rack-protection (= 2.2.2)
38
+ tilt (~> 2.0)
39
+ tilt (2.0.11)
40
+
41
+ PLATFORMS
42
+ arm64-darwin-20
43
+ arm64-darwin-21
44
+ x86_64-darwin-21
45
+ x86_64-linux
46
+
47
+ DEPENDENCIES
48
+ minitest
49
+ rails-autoscale-core!
50
+ rails-autoscale-resque!
51
+ rake
52
+
53
+ BUNDLED WITH
54
+ 2.3.9
data/Rakefile ADDED
@@ -0,0 +1,12 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "bundler/gem_tasks"
4
+ require "rake/testtask"
5
+
6
+ Rake::TestTask.new(:test) do |t|
7
+ t.libs << "lib"
8
+ t.libs << "test"
9
+ t.test_files = FileList["test/**/*_test.rb"]
10
+ end
11
+
12
+ task default: :test
@@ -0,0 +1,3 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "rails_autoscale/resque"
@@ -0,0 +1,23 @@
1
+ module RailsAutoscale
2
+ module Resque
3
+ module LatencyExtension
4
+ # Store the time when jobs are pushed to the queue in order to calculate latency.
5
+ def push(queue, item)
6
+ item["timestamp"] = Time.now.utc.to_f
7
+ super
8
+ end
9
+
10
+ # Calculate latency for the given queue using the stored timestamp of the oldest item in the queue.
11
+ def latency(queue)
12
+ if (item = peek(queue))
13
+ timestamp = item["timestamp"]
14
+ timestamp ? Time.now.utc.to_f - timestamp.to_f : 0.0
15
+ else
16
+ 0.0
17
+ end
18
+ end
19
+ end
20
+ end
21
+ end
22
+
23
+ ::Resque.extend(RailsAutoscale::Resque::LatencyExtension)
@@ -0,0 +1,48 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "rails_autoscale/job_metrics_collector"
4
+ require "rails_autoscale/metric"
5
+
6
+ module RailsAutoscale
7
+ module Resque
8
+ class MetricsCollector < RailsAutoscale::JobMetricsCollector
9
+ def self.adapter_config
10
+ RailsAutoscale::Config.instance.resque
11
+ end
12
+
13
+ def collect
14
+ metrics = []
15
+ current_queues = ::Resque.queues
16
+
17
+ if track_busy_jobs?
18
+ busy_counts = Hash.new { |h, k| h[k] = 0 }
19
+
20
+ ::Resque.working.each do |worker|
21
+ if !worker.idle? && (job = worker.job)
22
+ busy_counts[job["queue"]] += 1
23
+ end
24
+ end
25
+ end
26
+
27
+ self.queues |= current_queues
28
+
29
+ queues.each do |queue|
30
+ next if queue.nil? || queue.empty?
31
+ depth = ::Resque.size(queue)
32
+ latency = (::Resque.latency(queue) * 1000).ceil
33
+
34
+ metrics.push Metric.new(:qd, depth, Time.now, queue)
35
+ metrics.push Metric.new(:qt, latency, Time.now, queue)
36
+
37
+ if track_busy_jobs?
38
+ busy_count = busy_counts[queue]
39
+ metrics.push Metric.new(:busy, busy_count, Time.now, queue)
40
+ end
41
+ end
42
+
43
+ log_collection(metrics)
44
+ metrics
45
+ end
46
+ end
47
+ end
48
+ end
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RailsAutoscale
4
+ module Resque
5
+ VERSION = "1.0.0"
6
+ end
7
+ end
@@ -0,0 +1,16 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "rails-autoscale-core"
4
+ require "rails_autoscale/config"
5
+ require "rails_autoscale/resque/version"
6
+ require "rails_autoscale/resque/metrics_collector"
7
+ require "resque"
8
+ require "rails_autoscale/resque/latency_extension"
9
+
10
+ RailsAutoscale.add_adapter :"rails-autoscale-resque",
11
+ {
12
+ adapter_version: RailsAutoscale::Resque::VERSION,
13
+ framework_version: ::Resque::VERSION
14
+ },
15
+ metrics_collector: RailsAutoscale::Resque::MetricsCollector,
16
+ expose_config: RailsAutoscale::Config::JobAdapterConfig.new(:resque)
@@ -0,0 +1,30 @@
1
+ lib = File.expand_path("../lib", __FILE__)
2
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
+ require "rails_autoscale/resque/version"
4
+
5
+ Gem::Specification.new do |spec|
6
+ spec.name = "rails-autoscale-resque"
7
+ spec.version = RailsAutoscale::Resque::VERSION
8
+ spec.authors = ["Adam McCrea", "Carlos Antonio da Silva"]
9
+ spec.email = ["adam@adamlogic.com"]
10
+
11
+ spec.summary = "This gem provides Resque integration with the Rails Autoscale autoscaling add-on for Heroku."
12
+ spec.homepage = "https://railsautoscale.com"
13
+ spec.license = "MIT"
14
+
15
+ spec.metadata = {
16
+ "homepage_uri" => "https://railsautoscale.com",
17
+ "bug_tracker_uri" => "https://github.com/rails-autoscale/rails-autoscale-gems/issues",
18
+ "documentation_uri" => "https://railsautoscale.com/docs",
19
+ "changelog_uri" => "https://github.com/rails-autoscale/rails-autoscale-gems/blob/main/CHANGELOG.md",
20
+ "source_code_uri" => "https://github.com/rails-autoscale/rails-autoscale-gems"
21
+ }
22
+
23
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
24
+ spec.require_paths = ["lib"]
25
+
26
+ spec.required_ruby_version = ">= 2.6.0"
27
+
28
+ spec.add_dependency "rails-autoscale-core"
29
+ spec.add_dependency "resque", ">= 2.0"
30
+ end
metadata ADDED
@@ -0,0 +1,87 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rails-autoscale-resque
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Adam McCrea
8
+ - Carlos Antonio da Silva
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2022-09-07 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: rails-autoscale-core
16
+ requirement: !ruby/object:Gem::Requirement
17
+ requirements:
18
+ - - ">="
19
+ - !ruby/object:Gem::Version
20
+ version: '0'
21
+ type: :runtime
22
+ prerelease: false
23
+ version_requirements: !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - ">="
26
+ - !ruby/object:Gem::Version
27
+ version: '0'
28
+ - !ruby/object:Gem::Dependency
29
+ name: resque
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - ">="
33
+ - !ruby/object:Gem::Version
34
+ version: '2.0'
35
+ type: :runtime
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - ">="
40
+ - !ruby/object:Gem::Version
41
+ version: '2.0'
42
+ description:
43
+ email:
44
+ - adam@adamlogic.com
45
+ executables: []
46
+ extensions: []
47
+ extra_rdoc_files: []
48
+ files:
49
+ - Gemfile
50
+ - Gemfile.lock
51
+ - Rakefile
52
+ - lib/rails-autoscale-resque.rb
53
+ - lib/rails_autoscale/resque.rb
54
+ - lib/rails_autoscale/resque/latency_extension.rb
55
+ - lib/rails_autoscale/resque/metrics_collector.rb
56
+ - lib/rails_autoscale/resque/version.rb
57
+ - rails-autoscale-resque.gemspec
58
+ homepage: https://railsautoscale.com
59
+ licenses:
60
+ - MIT
61
+ metadata:
62
+ homepage_uri: https://railsautoscale.com
63
+ bug_tracker_uri: https://github.com/rails-autoscale/rails-autoscale-gems/issues
64
+ documentation_uri: https://railsautoscale.com/docs
65
+ changelog_uri: https://github.com/rails-autoscale/rails-autoscale-gems/blob/main/CHANGELOG.md
66
+ source_code_uri: https://github.com/rails-autoscale/rails-autoscale-gems
67
+ post_install_message:
68
+ rdoc_options: []
69
+ require_paths:
70
+ - lib
71
+ required_ruby_version: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: 2.6.0
76
+ required_rubygems_version: !ruby/object:Gem::Requirement
77
+ requirements:
78
+ - - ">="
79
+ - !ruby/object:Gem::Version
80
+ version: '0'
81
+ requirements: []
82
+ rubygems_version: 3.2.32
83
+ signing_key:
84
+ specification_version: 4
85
+ summary: This gem provides Resque integration with the Rails Autoscale autoscaling
86
+ add-on for Heroku.
87
+ test_files: []