#855: cid:priority

This commit is contained in:
Anton Martynov 2015-11-03 13:08:31 +03:00
parent 2f2f446def
commit da2a68f451
2 changed files with 41 additions and 23 deletions

View File

@ -323,6 +323,7 @@ module Provider
'key_name' => instance["keyName"], 'key_name' => instance["keyName"],
'private_ip' => instance["privateIpAddress"], 'private_ip' => instance["privateIpAddress"],
'public_ip' => instance["ipAddress"], 'public_ip' => instance["ipAddress"],
'tags' => instance["tagSet"]
} }
end end
end end

View File

@ -26,9 +26,15 @@ class StackBootstrapWorker < Worker
return 1 return 1
end end
#TODO: errors
begin begin
servers = persist_stack_servers!(stack) servers_with_priority = persist_stack_servers!(stack)
bootstrap_servers!(servers, report) unless without_bootstrap unless without_bootstrap
sorted_keys = servers_with_priority.keys.sort{|x,y| y <=> x}
sorted_keys.each do |key|
bootstrap_servers!(servers_with_priority[key], report)
end
end
rescue BootstrapingStackServerError rescue BootstrapingStackServerError
@out.puts "\nAn error occured during bootstraping stack servers. Initiating stack rollback." @out.puts "\nAn error occured during bootstraping stack servers. Initiating stack rollback."
rollback_stack!(stack) rollback_stack!(stack)
@ -75,7 +81,7 @@ class StackBootstrapWorker < Worker
def bootstrap_servers!(servers, report) def bootstrap_servers!(servers, report)
@out << "\nStart bootstraping stack servers\n" @out << "\nStart bootstraping stack servers\n"
report.subreports = subreports = [] subreports = []
data = {} data = {}
servers.each do |server| servers.each do |server|
sjid = Worker.start_async(BootstrapWorker, sjid = Worker.start_async(BootstrapWorker,
@ -153,6 +159,10 @@ class StackBootstrapWorker < Worker
report report
end end
# returns
# {
# "priority" => [Servers]
# }
def persist_stack_servers!(stack) def persist_stack_servers!(stack)
@out.puts "Start syncing stack servers with CID" @out.puts "Start syncing stack servers with CID"
@out.flush @out.flush
@ -160,7 +170,10 @@ class StackBootstrapWorker < Worker
deploy_env = project.deploy_env(stack.deploy_env) deploy_env = project.deploy_env(stack.deploy_env)
provider = stack.provider_instance provider = stack.provider_instance
servers = provider.stack_servers(stack).map do |extended_info| stack_servers_info = provider.stack_servers(stack).group_by{|info| info["tags"]["cid:priority"] || 0}
stack_servers_with_priority = {}
stack_servers_info.each do |priority, info_array|
stack_servers_with_priority[priority] = info_array.map do |extended_info|
server_attrs = { server_attrs = {
'provider' => provider.name, 'provider' => provider.name,
'project' => project.id, 'project' => project.id,
@ -181,9 +194,13 @@ class StackBootstrapWorker < Worker
# server.chef_node_name = provider.create_default_chef_node_name(server) # server.chef_node_name = provider.create_default_chef_node_name(server)
server server
end end
end
@out.puts "Stack servers have been synced with CID" @out.puts "Stack servers have been synced with CID"
stack_servers_info.each do |priority, servers|
@out.puts "Priority '#{priority}': #{servers.map(&:id).join(", ")}"
end
@out.flush @out.flush
servers stack_servers_with_priority
end end
end end