From 6b12feeaed13db5ee2bd876f38dbf1ff41be1729 Mon Sep 17 00:00:00 2001 From: Madhurranjan Mohaan Date: Wed, 2 Oct 2013 10:03:55 +0530 Subject: [PATCH] Limits the number of concurrent vm creations to make sure vms are created successfully --- lib/vagrant-aws/action/run_instance.rb | 28 +++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/lib/vagrant-aws/action/run_instance.rb b/lib/vagrant-aws/action/run_instance.rb index 9af4915f..dcbedf38 100644 --- a/lib/vagrant-aws/action/run_instance.rb +++ b/lib/vagrant-aws/action/run_instance.rb @@ -12,9 +12,25 @@ module Action class RunInstance include Vagrant::Util::Retryable + @@instances = 0 + LIMIT = 10 + + def self.update_instances + @@instances = @@instances + 1 + end + + def self.instances + @@instances + end + def initialize(app, env) + RunInstance.update_instances @app = app + @instance_no = RunInstance.instances + @iteration = 1 @logger = Log4r::Logger.new("vagrant_aws::action::run_instance") + @logger.debug("Instance no - #{@instance_no}") + control_vm_creation end def call(env) @@ -123,7 +139,7 @@ def call(env) next if env[:interrupted] # Wait for the server to be ready - server.wait_for(2) { ready? } + server.wait_for(10) { ready? } end rescue Fog::Errors::TimeoutError # Delete the instance @@ -232,6 +248,16 @@ def terminate(env) destroy_env[:force_confirm_destroy] = true env[:action_runner].run(Action.action_destroy, destroy_env) end + + private + + def control_vm_creation + while @instance_no > (LIMIT * @iteration) do + @iteration = @iteration + 1 + @logger.debug("----------------instance_no - #{@instance_no} will wait-----------------") + sleep 30 + end + end end end end