Skip to content

Commit

Permalink
Merge pull request #19238 from fdupont-redhat/v2v_state_machine_apply…
Browse files Browse the repository at this point in the history
…_right_size

[V2V] Add applying_right_sizing state to InfraConversionJob

(cherry picked from commit 7a820ad)

https://bugzilla.redhat.com/show_bug.cgi?id=1768522
  • Loading branch information
agrare authored and simaishi committed Feb 21, 2020
1 parent 184487b commit 94c02b5
Show file tree
Hide file tree
Showing 4 changed files with 243 additions and 37 deletions.
84 changes: 70 additions & 14 deletions app/models/infra_conversion_job.rb
Original file line number Diff line number Diff line change
Expand Up @@ -44,9 +44,14 @@ def load_transitions
:poll_shutdown_vm_complete => {'shutting_down_vm' => 'shutting_down_vm'},
:transform_vm => {'shutting_down_vm' => 'transforming_vm'},
:poll_transform_vm_complete => {'transforming_vm' => 'transforming_vm'},
:poll_inventory_refresh_complete => {
'transforming_vm' => 'waiting_for_inventory_refresh',
'waiting_for_inventory_refresh' => 'waiting_for_inventory_refresh'
},
:apply_right_sizing => {'waiting_for_inventory_refresh' => 'applying_right_sizing'},
:poll_automate_state_machine => {
'transforming_vm' => 'running_in_automate',
'running_in_automate' => 'running_in_automate'
'applying_right_sizing' => 'running_in_automate',
'running_in_automate' => 'running_in_automate'
},
:finish => {'*' => 'finished'},
:abort_job => {'*' => 'aborting'},
Expand All @@ -63,32 +68,41 @@ def load_transitions
# }
def state_settings
@state_settings ||= {
:removing_snapshots => {
:removing_snapshots => {
:description => 'Remove snapshosts',
:weight => 5,
:max_retries => 4.hours / state_retry_interval
},
:waiting_for_ip_address => {
:waiting_for_ip_address => {
:description => 'Waiting for VM IP address',
:weight => 1,
:max_retries => 1.hour / state_retry_interval
},
:running_migration_playbook => {
:running_migration_playbook => {
:description => "Running #{migration_phase}-migration playbook",
:weight => 10,
:max_retries => 6.hours / state_retry_interval
},
:shutting_down_vm => {
:shutting_down_vm => {
:description => "Shutting down virtual machine",
:weight => 1,
:max_retries => 15.minutes / state_retry_interval
},
:transforming_vm => {
:transforming_vm => {
:description => "Converting disks",
:weight => 60,
:max_retries => 1.day / state_retry_interval
},
:running_in_automate => {
:waiting_for_inventory_refresh => {
:description => "Identify destination VM",
:weight => 4,
:max_retries => 1.hour / state_retry_interval
},
:applying_right_sizing => {
:description => "Apply Right-Sizing Recommendation",
:weight => 1
},
:running_in_automate => {
:max_retries => 36.hours / state_retry_interval
}
}
Expand All @@ -112,11 +126,7 @@ def source_vm
end

def destination_vm
return nil if migration_task.options[:destination_vm_id].nil?

@destination_vm ||= Vm.find(migration_task.options[:destination_vm_id]).tap do |vm|
raise "No Vm in VMDB with id #{migration_task.options[:destination_vm_id]}" if vm.nil?
end
@destination_vm ||= migration_task.destination
end

def target_vm
Expand Down Expand Up @@ -214,6 +224,14 @@ def order_ansible_playbook_service
service_template.provision_request(migration_task.userid.to_i, service_dialog_options)
end

def apply_right_sizing_cpu(mode)
destination_vm.set_number_of_cpus(source_vm.send("#{mode}_recommended_vcpus"))
end

def apply_right_sizing_memory(mode)
destination_vm.set_memory(source_vm.send("#{mode}_recommended_mem"))
end

# --- Methods that implement the state machine transitions --- #

# This transition simply allows to officially mark the task as migrating.
Expand Down Expand Up @@ -394,14 +412,52 @@ def poll_transform_vm_complete
raise migration_task.options[:virtv2v_message]
when 'succeeded'
update_migration_task_progress(:on_exit)
handover_to_automate
queue_signal(:poll_automate_state_machine)
end
rescue StandardError => error
update_migration_task_progress(:on_error)
abort_conversion(error.message, 'error')
end

# This methods waits for the destination EMS inventory to refresh.
# It updates the migration_task.destination relationship with the create VM.
# We don't force the EMS refresh and rather allow 1 hour to get it.
def poll_inventory_refresh_complete
update_migration_task_progress(:on_entry)
return abort_conversion('Identify destination VM timed out', 'error') if polling_timeout

destination_vm = Vm.find_by(:name => migration_task.source.name, :ems_id => migration_task.destination_ems.id)
if destination_vm.nil?
update_migration_task_progress(:on_retry)
return queue_signal(:poll_inventory_refresh_complete, :deliver_on => Time.now.utc + state_retry_interval)
end

migration_task.update!(:destination => destination_vm)
migration_task.update_options(:migration_phase => 'post')
update_migration_task_progress(:on_exit)
queue_signal(:apply_right_sizing)
rescue StandardError => error
update_migration_task_progress(:on_error)
abort_conversion(error.message, 'error')
end

def apply_right_sizing
update_migration_task_progress(:on_entry)

%i[cpu memory].each do |item|
right_sizing_mode = migration_task.send("#{item}_right_sizing_mode")
send("apply_right_sizing_#{item}", right_sizing_mode) if right_sizing_mode.present?
end

update_migration_task_progress(:on_exit)
handover_to_automate
queue_signal(:poll_automate_state_machine)
rescue StandardError
update_migration_task_progress(:on_error)
handover_to_automate
queue_signal(:poll_automate_state_machine)
end

def poll_automate_state_machine
return abort_conversion('Polling Automate state machine timed out', 'error') if polling_timeout

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@ def validate_config_info(options)
vm_options[:post_ansible_playbook_service_template_id] = post_service_id if vm_hash[:post_service]
vm_options[:osp_security_group_id] = vm_hash[:osp_security_group_id] if vm_hash[:osp_security_group_id].present?
vm_options[:osp_flavor_id] = vm_hash[:osp_flavor_id] if vm_hash[:osp_flavor_id].present?
vm_options[:cpu_right_sizing_mode] = vm_hash[:cpu_right_sizing_mode] if vm_hash[:cpu_right_sizing_mode].present?
vm_options[:memory_right_sizing_mode] = vm_hash[:memory_right_sizing_mode] if vm_hash[:memory_right_sizing_mode].present?
vms << {:vm => vm_obj, :options => vm_options}
end
end
Expand Down
8 changes: 8 additions & 0 deletions app/models/service_template_transformation_plan_task.rb
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,14 @@ def post_ansible_playbook_service_template
ServiceTemplate.find_by(:id => vm_resource.options["post_ansible_playbook_service_template_id"])
end

def cpu_right_sizing_mode
vm_resource.options["cpu_right_sizing_mode"]
end

def memory_right_sizing_mode
vm_resource.options["memory_right_sizing_mode"]
end

def update_transformation_progress(progress)
update_options(:progress => (options[:progress] || {}).merge(progress))
end
Expand Down
Loading

0 comments on commit 94c02b5

Please sign in to comment.