nimble_nodes 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/.document ADDED
@@ -0,0 +1,5 @@
1
+ README.rdoc
2
+ lib/**/*.rb
3
+ bin/*
4
+ features/**/*.feature
5
+ LICENSE
data/.gitignore ADDED
@@ -0,0 +1,21 @@
1
+ ## MAC OS
2
+ .DS_Store
3
+
4
+ ## TEXTMATE
5
+ *.tmproj
6
+ tmtags
7
+
8
+ ## EMACS
9
+ *~
10
+ \#*
11
+ .\#*
12
+
13
+ ## VIM
14
+ *.swp
15
+
16
+ ## PROJECT::GENERAL
17
+ coverage
18
+ rdoc
19
+ pkg
20
+
21
+ ## PROJECT::SPECIFIC
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2009 Jordan Glasner
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.rdoc ADDED
@@ -0,0 +1,24 @@
1
+ = NimbleNodes
2
+
3
+ Automatic scaling for Heroku Dynos (and Delayed Job Workers coming soon). See http://nimblenodes.com for more information.
4
+
5
+ Rack middleware sits on top of all requests and watches the number of Dynos in use and the size of the RequestQueue. Depending on the settings entered at http://nimblenodes.com reports are posted over to the server. The server then calculates the needed adjustments and handles all communications with Heroku.
6
+
7
+ == Installation
8
+
9
+ === Install gem
10
+
11
+ sudo gem install nimble_nodes
12
+
13
+ === Rails installation
14
+
15
+ In config/enviroment.rb
16
+
17
+ config.gem 'nimble_nodes'
18
+ config.middleware.use NimbleNodes::Middleware
19
+
20
+ ENV['NN_TOKEN'] = 'api_token_for_app'
21
+
22
+ == Copyright
23
+
24
+ Copyright (c) 2010 Cotillion, LLC. See LICENSE for details.
data/Rakefile ADDED
@@ -0,0 +1,53 @@
1
+ require 'rubygems'
2
+ require 'rake'
3
+
4
+ begin
5
+ require 'jeweler'
6
+ Jeweler::Tasks.new do |gem|
7
+ gem.name = "nimble_nodes"
8
+ gem.summary = "gem for connecting apps to the NimbleNodes server"
9
+ gem.description = "automatically scales dynos and workers at Heroku"
10
+ gem.email = "jordan@digitalignition.com"
11
+ gem.homepage = "http://github.com/glasner/nimble_nodes"
12
+ gem.authors = ["Jordan Glasner"]
13
+ gem.add_development_dependency "thoughtbot-shoulda", ">= 0"
14
+ # gem is a Gem::Specification... see http://www.rubygems.org/read/chapter/20 for additional settings
15
+ end
16
+ Jeweler::GemcutterTasks.new
17
+ rescue LoadError
18
+ puts "Jeweler (or a dependency) not available. Install it with: gem install jeweler"
19
+ end
20
+
21
+ require 'rake/testtask'
22
+ Rake::TestTask.new(:test) do |test|
23
+ test.libs << 'lib' << 'test'
24
+ test.pattern = 'test/**/test_*.rb'
25
+ test.verbose = true
26
+ end
27
+
28
+ begin
29
+ require 'rcov/rcovtask'
30
+ Rcov::RcovTask.new do |test|
31
+ test.libs << 'test'
32
+ test.pattern = 'test/**/test_*.rb'
33
+ test.verbose = true
34
+ end
35
+ rescue LoadError
36
+ task :rcov do
37
+ abort "RCov is not available. In order to run rcov, you must: sudo gem install spicycode-rcov"
38
+ end
39
+ end
40
+
41
+ task :test => :check_dependencies
42
+
43
+ task :default => :test
44
+
45
+ require 'rake/rdoctask'
46
+ Rake::RDocTask.new do |rdoc|
47
+ version = File.exist?('VERSION') ? File.read('VERSION') : ""
48
+
49
+ rdoc.rdoc_dir = 'rdoc'
50
+ rdoc.title = "nimble_nodes #{version}"
51
+ rdoc.rdoc_files.include('README*')
52
+ rdoc.rdoc_files.include('lib/**/*.rb')
53
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.1.0
@@ -0,0 +1,15 @@
1
+ module NimbleNodes
2
+
3
+ module Dynos
4
+
5
+ def self.max
6
+ ENV['NN_DYNO_POOL_MAX']
7
+ end
8
+
9
+ def self.max_request_queue
10
+ ENV['NN_DYNOS_REQUEST_QUEUE_MAX']
11
+ end
12
+
13
+ end
14
+
15
+ end
@@ -0,0 +1,15 @@
1
+ module NimbleNodes
2
+ class Middleware
3
+ def initialize(app)
4
+ @app = app
5
+ end
6
+
7
+
8
+ def call(env)
9
+ @report = NimbleNodes::Report.new
10
+ @report.post if @report.post?
11
+ # now, execute the request using our Rails app
12
+ response = @app.call(env)
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,33 @@
1
+ module NimbleNodes
2
+
3
+ class Report
4
+ def initializer
5
+ @dynos_in_use = ENV['HTTP_X_HEROKU_DYNOS_IN_USE']
6
+ @request_queue_depth = ENV['HTTP_X_HEROKU_QUEUE_DEPTH']
7
+ end
8
+
9
+ def post
10
+ params = {
11
+ :dynos_in_use => @dynos_in_use,
12
+ :request_queue_size => @request_queue_depth }
13
+ NimbleNodes::Server.post('/dynos/reports.json', params)
14
+ end
15
+
16
+ def post?
17
+ return true
18
+ dynos_maxed_out? or queue_depth_too_long?
19
+ end
20
+
21
+ def dynos_maxed_out?
22
+ return false if @dynos_in_use.nil?
23
+ @dynos_in_use >= Dynos.max
24
+ end
25
+
26
+ def queue_depth_too_long?
27
+ return false if @request_queue_depth.nil?
28
+ @request_queue_depth > Dynos.max_request_queue
29
+ end
30
+
31
+ end
32
+
33
+ end
@@ -0,0 +1,21 @@
1
+ require 'net/http'
2
+
3
+ module NimbleNodes
4
+
5
+ class Server
6
+
7
+ def self.post(path,args)
8
+ url = URI.parse(url_to(path))
9
+ request = Net::HTTP::Post.new(url.path)
10
+ request.set_form_data({:token => ENV['NN_TOKEN'], :json => args.to_json })
11
+ response = Net::HTTP.start(url.host, url.port) {|http| http.request(request)}
12
+ end
13
+
14
+ def self.url_to(path)
15
+ 'http://' + ENV['NN_SERVER_DOMAIN'] + path
16
+ # 'http://nimblenodes.com' + path
17
+ end
18
+
19
+ end
20
+
21
+ end
@@ -0,0 +1,10 @@
1
+ module NimbleNodes
2
+ end
3
+
4
+
5
+ current_path = File.dirname(__FILE__)
6
+
7
+ %w(dynos report server middleware).each do |file|
8
+ require "#{current_path}/nimble_nodes/#{file}"
9
+ end
10
+
data/test/helper.rb ADDED
@@ -0,0 +1,10 @@
1
+ require 'rubygems'
2
+ require 'test/unit'
3
+ require 'shoulda'
4
+
5
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
6
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
7
+ require 'nimble_nodes'
8
+
9
+ class Test::Unit::TestCase
10
+ end
@@ -0,0 +1,7 @@
1
+ require 'helper'
2
+
3
+ class TestNimbleNodes < Test::Unit::TestCase
4
+ should "probably rename this file and start testing for real" do
5
+ flunk "hey buddy, you should probably rename this file and start testing for real"
6
+ end
7
+ end
metadata ADDED
@@ -0,0 +1,78 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: nimble_nodes
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Jordan Glasner
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+
12
+ date: 2010-03-03 00:00:00 -05:00
13
+ default_executable:
14
+ dependencies:
15
+ - !ruby/object:Gem::Dependency
16
+ name: thoughtbot-shoulda
17
+ type: :development
18
+ version_requirement:
19
+ version_requirements: !ruby/object:Gem::Requirement
20
+ requirements:
21
+ - - ">="
22
+ - !ruby/object:Gem::Version
23
+ version: "0"
24
+ version:
25
+ description: automatically scales dynos and workers at Heroku
26
+ email: jordan@digitalignition.com
27
+ executables: []
28
+
29
+ extensions: []
30
+
31
+ extra_rdoc_files:
32
+ - LICENSE
33
+ - README.rdoc
34
+ files:
35
+ - .document
36
+ - .gitignore
37
+ - LICENSE
38
+ - README.rdoc
39
+ - Rakefile
40
+ - VERSION
41
+ - lib/nimble_nodes.rb
42
+ - lib/nimble_nodes/dynos.rb
43
+ - lib/nimble_nodes/middleware.rb
44
+ - lib/nimble_nodes/report.rb
45
+ - lib/nimble_nodes/server.rb
46
+ - test/helper.rb
47
+ - test/test_nimble_nodes.rb
48
+ has_rdoc: true
49
+ homepage: http://github.com/glasner/nimble_nodes
50
+ licenses: []
51
+
52
+ post_install_message:
53
+ rdoc_options:
54
+ - --charset=UTF-8
55
+ require_paths:
56
+ - lib
57
+ required_ruby_version: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: "0"
62
+ version:
63
+ required_rubygems_version: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - ">="
66
+ - !ruby/object:Gem::Version
67
+ version: "0"
68
+ version:
69
+ requirements: []
70
+
71
+ rubyforge_project:
72
+ rubygems_version: 1.3.5
73
+ signing_key:
74
+ specification_version: 3
75
+ summary: gem for connecting apps to the NimbleNodes server
76
+ test_files:
77
+ - test/helper.rb
78
+ - test/test_nimble_nodes.rb