mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	[Vmware to KVM Migration] Display virt-v2v and ovftool versions for supported hosts for migration (#11019)
* [Vmware to KVM Migration] Display virt-v2v and ovftool versions for supported hosts for migration * Fix UI display * Address review comments * Fix ovftool and version display - also display versions on host details view
This commit is contained in:
		
							parent
							
								
									5790091b25
								
							
						
					
					
						commit
						75147b7811
					
				| @ -53,9 +53,12 @@ public interface Host extends StateObject<Status>, Identity, Partition, HAResour | |||||||
|             return strs; |             return strs; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     public static final String HOST_UEFI_ENABLE = "host.uefi.enable"; | 
 | ||||||
|     public static final String HOST_VOLUME_ENCRYPTION = "host.volume.encryption"; |     String HOST_UEFI_ENABLE = "host.uefi.enable"; | ||||||
|     public static final String HOST_INSTANCE_CONVERSION = "host.instance.conversion"; |     String HOST_VOLUME_ENCRYPTION = "host.volume.encryption"; | ||||||
|  |     String HOST_INSTANCE_CONVERSION = "host.instance.conversion"; | ||||||
|  |     String HOST_OVFTOOL_VERSION = "host.ovftool.version"; | ||||||
|  |     String HOST_VIRTV2V_VERSION = "host.virtv2v.version"; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * @return name of the machine. |      * @return name of the machine. | ||||||
|  | |||||||
| @ -54,6 +54,7 @@ import org.apache.cloudstack.utils.identity.ManagementServerNode; | |||||||
| import org.apache.cloudstack.utils.reflectiontostringbuilderutils.ReflectionToStringBuilderUtils; | import org.apache.cloudstack.utils.reflectiontostringbuilderutils.ReflectionToStringBuilderUtils; | ||||||
| import org.apache.commons.collections.MapUtils; | import org.apache.commons.collections.MapUtils; | ||||||
| import org.apache.commons.lang3.BooleanUtils; | import org.apache.commons.lang3.BooleanUtils; | ||||||
|  | import org.apache.commons.lang3.ObjectUtils; | ||||||
| import org.apache.commons.lang3.StringUtils; | import org.apache.commons.lang3.StringUtils; | ||||||
| import org.apache.logging.log4j.ThreadContext; | import org.apache.logging.log4j.ThreadContext; | ||||||
| 
 | 
 | ||||||
| @ -703,11 +704,25 @@ public class AgentManagerImpl extends ManagerBase implements AgentManager, Handl | |||||||
|             Map<String, String> detailsMap = readyAnswer.getDetailsMap(); |             Map<String, String> detailsMap = readyAnswer.getDetailsMap(); | ||||||
|             if (detailsMap != null) { |             if (detailsMap != null) { | ||||||
|                 String uefiEnabled = detailsMap.get(Host.HOST_UEFI_ENABLE); |                 String uefiEnabled = detailsMap.get(Host.HOST_UEFI_ENABLE); | ||||||
|  |                 String virtv2vVersion = detailsMap.get(Host.HOST_VIRTV2V_VERSION); | ||||||
|  |                 String ovftoolVersion = detailsMap.get(Host.HOST_OVFTOOL_VERSION); | ||||||
|                 logger.debug("Got HOST_UEFI_ENABLE [{}] for host [{}]:", uefiEnabled, host); |                 logger.debug("Got HOST_UEFI_ENABLE [{}] for host [{}]:", uefiEnabled, host); | ||||||
|                 if (uefiEnabled != null) { |                 if (ObjectUtils.anyNotNull(uefiEnabled, virtv2vVersion, ovftoolVersion)) { | ||||||
|                     _hostDao.loadDetails(host); |                     _hostDao.loadDetails(host); | ||||||
|  |                     boolean updateNeeded = false; | ||||||
|                     if (!uefiEnabled.equals(host.getDetails().get(Host.HOST_UEFI_ENABLE))) { |                     if (!uefiEnabled.equals(host.getDetails().get(Host.HOST_UEFI_ENABLE))) { | ||||||
|                         host.getDetails().put(Host.HOST_UEFI_ENABLE, uefiEnabled); |                         host.getDetails().put(Host.HOST_UEFI_ENABLE, uefiEnabled); | ||||||
|  |                         updateNeeded = true; | ||||||
|  |                     } | ||||||
|  |                     if (StringUtils.isNotBlank(virtv2vVersion) && !virtv2vVersion.equals(host.getDetails().get(Host.HOST_VIRTV2V_VERSION))) { | ||||||
|  |                         host.getDetails().put(Host.HOST_VIRTV2V_VERSION, virtv2vVersion); | ||||||
|  |                         updateNeeded = true; | ||||||
|  |                     } | ||||||
|  |                     if (StringUtils.isNotBlank(ovftoolVersion) && !ovftoolVersion.equals(host.getDetails().get(Host.HOST_OVFTOOL_VERSION))) { | ||||||
|  |                         host.getDetails().put(Host.HOST_OVFTOOL_VERSION, ovftoolVersion); | ||||||
|  |                         updateNeeded = true; | ||||||
|  |                     } | ||||||
|  |                     if (updateNeeded) { | ||||||
|                         _hostDao.saveDetails(host); |                         _hostDao.saveDetails(host); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  | |||||||
| @ -17,6 +17,8 @@ | |||||||
| package com.cloud.hypervisor.kvm.resource; | package com.cloud.hypervisor.kvm.resource; | ||||||
| 
 | 
 | ||||||
| import static com.cloud.host.Host.HOST_INSTANCE_CONVERSION; | import static com.cloud.host.Host.HOST_INSTANCE_CONVERSION; | ||||||
|  | import static com.cloud.host.Host.HOST_OVFTOOL_VERSION; | ||||||
|  | import static com.cloud.host.Host.HOST_VIRTV2V_VERSION; | ||||||
| import static com.cloud.host.Host.HOST_VOLUME_ENCRYPTION; | import static com.cloud.host.Host.HOST_VOLUME_ENCRYPTION; | ||||||
| 
 | 
 | ||||||
| import java.io.BufferedReader; | import java.io.BufferedReader; | ||||||
| @ -3766,7 +3768,14 @@ public class LibvirtComputingResource extends ServerResourceBase implements Serv | |||||||
|         cmd.setIqn(getIqn()); |         cmd.setIqn(getIqn()); | ||||||
|         cmd.getHostDetails().put(HOST_VOLUME_ENCRYPTION, String.valueOf(hostSupportsVolumeEncryption())); |         cmd.getHostDetails().put(HOST_VOLUME_ENCRYPTION, String.valueOf(hostSupportsVolumeEncryption())); | ||||||
|         cmd.setHostTags(getHostTags()); |         cmd.setHostTags(getHostTags()); | ||||||
|         cmd.getHostDetails().put(HOST_INSTANCE_CONVERSION, String.valueOf(hostSupportsInstanceConversion())); |         boolean instanceConversionSupported = hostSupportsInstanceConversion(); | ||||||
|  |         cmd.getHostDetails().put(HOST_INSTANCE_CONVERSION, String.valueOf(instanceConversionSupported)); | ||||||
|  |         if (instanceConversionSupported) { | ||||||
|  |             cmd.getHostDetails().put(HOST_VIRTV2V_VERSION, getHostVirtV2vVersion()); | ||||||
|  |         } | ||||||
|  |         if (hostSupportsOvfExport()) { | ||||||
|  |             cmd.getHostDetails().put(HOST_OVFTOOL_VERSION, getHostOvfToolVersion()); | ||||||
|  |         } | ||||||
|         HealthCheckResult healthCheckResult = getHostHealthCheckResult(); |         HealthCheckResult healthCheckResult = getHostHealthCheckResult(); | ||||||
|         if (healthCheckResult != HealthCheckResult.IGNORE) { |         if (healthCheckResult != HealthCheckResult.IGNORE) { | ||||||
|             cmd.setHostHealthCheckResult(healthCheckResult == HealthCheckResult.SUCCESS); |             cmd.setHostHealthCheckResult(healthCheckResult == HealthCheckResult.SUCCESS); | ||||||
| @ -5368,8 +5377,24 @@ public class LibvirtComputingResource extends ServerResourceBase implements Serv | |||||||
|         return exitValue == 0; |         return exitValue == 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public String getHostVirtV2vVersion() { | ||||||
|  |         if (!hostSupportsInstanceConversion()) { | ||||||
|  |             return ""; | ||||||
|  |         } | ||||||
|  |         String cmd = String.format("%s | awk '{print $2}'", INSTANCE_CONVERSION_SUPPORTED_CHECK_CMD); | ||||||
|  |         String version = Script.runSimpleBashScript(cmd); | ||||||
|  |         return StringUtils.isNotBlank(version) ? version.split(",")[0] : ""; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getHostOvfToolVersion() { | ||||||
|  |         if (!hostSupportsOvfExport()) { | ||||||
|  |             return ""; | ||||||
|  |         } | ||||||
|  |         return Script.runSimpleBashScript(OVF_EXPORT_TOOl_GET_VERSION_CMD); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public boolean ovfExportToolSupportsParallelThreads() { |     public boolean ovfExportToolSupportsParallelThreads() { | ||||||
|         String ovfExportToolVersion = Script.runSimpleBashScript(OVF_EXPORT_TOOl_GET_VERSION_CMD); |         String ovfExportToolVersion = getHostOvfToolVersion(); | ||||||
|         if (StringUtils.isBlank(ovfExportToolVersion)) { |         if (StringUtils.isBlank(ovfExportToolVersion)) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -47,6 +47,14 @@ public final class LibvirtReadyCommandWrapper extends CommandWrapper<ReadyComman | |||||||
|             hostDetails.put(Host.HOST_UEFI_ENABLE, Boolean.TRUE.toString()); |             hostDetails.put(Host.HOST_UEFI_ENABLE, Boolean.TRUE.toString()); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         if (libvirtComputingResource.hostSupportsInstanceConversion()) { | ||||||
|  |             hostDetails.put(Host.HOST_VIRTV2V_VERSION, libvirtComputingResource.getHostVirtV2vVersion()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (libvirtComputingResource.hostSupportsOvfExport()) { | ||||||
|  |             hostDetails.put(Host.HOST_OVFTOOL_VERSION, libvirtComputingResource.getHostOvfToolVersion()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         return new ReadyAnswer(command, hostDetails); |         return new ReadyAnswer(command, hostDetails); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1089,7 +1089,9 @@ | |||||||
| "label.host": "IP address", | "label.host": "IP address", | ||||||
| "label.host.alerts": "Hosts in alert state", | "label.host.alerts": "Hosts in alert state", | ||||||
| "label.host.name": "Host name", | "label.host.name": "Host name", | ||||||
|  | "label.host.ovftool.version": "OVFTool Version", | ||||||
| "label.host.tag": "Host tag", | "label.host.tag": "Host tag", | ||||||
|  | "label.host.virtv2v.version": "Virt-v2v Version", | ||||||
| "label.hostcontrolstate": "Compute Resource Status", | "label.hostcontrolstate": "Compute Resource Status", | ||||||
| "label.hostid": "Host", | "label.hostid": "Host", | ||||||
| "label.hostname": "Host", | "label.hostname": "Host", | ||||||
|  | |||||||
| @ -56,6 +56,22 @@ | |||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </a-list-item> |       </a-list-item> | ||||||
|  |       <a-list-item v-if="host.details && host.details['host.virtv2v.version']"> | ||||||
|  |         <div> | ||||||
|  |           <strong>{{ $t('label.host.virtv2v.version') }}</strong> | ||||||
|  |           <div> | ||||||
|  |             {{ host.details['host.virtv2v.version'] }} | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </a-list-item> | ||||||
|  |       <a-list-item v-if="host.details && host.details['host.ovftool.version']"> | ||||||
|  |         <div> | ||||||
|  |           <strong>{{ $t('label.host.ovftool.version') }}</strong> | ||||||
|  |           <div> | ||||||
|  |             {{ host.details['host.ovftool.version'] }} | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </a-list-item> | ||||||
|       <a-list-item v-if="host.hosttags"> |       <a-list-item v-if="host.hosttags"> | ||||||
|         <div> |         <div> | ||||||
|           <strong>{{ $t('label.hosttags') }}</strong> |           <strong>{{ $t('label.hosttags') }}</strong> | ||||||
|  | |||||||
| @ -944,6 +944,12 @@ export default { | |||||||
|           } else { |           } else { | ||||||
|             host.name = host.name + ' (' + this.$t('label.not.supported') + ')' |             host.name = host.name + ' (' + this.$t('label.not.supported') + ')' | ||||||
|           } |           } | ||||||
|  |           if (host.details['host.virtv2v.version']) { | ||||||
|  |             host.name = host.name + ' (virt-v2v=' + host.details['host.virtv2v.version'] + ')' | ||||||
|  |           } | ||||||
|  |           if (host.details['host.ovftool.version']) { | ||||||
|  |             host.name = host.name + ' (ovftool=' + host.details['host.ovftool.version'] + ')' | ||||||
|  |           } | ||||||
|         }) |         }) | ||||||
|       }) |       }) | ||||||
|     }, |     }, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user