mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Some more refactoring
This commit is contained in:
		
							parent
							
								
									b0cfdf1f37
								
							
						
					
					
						commit
						3870d8f1dc
					
				| @ -1,133 +1,134 @@ | |||||||
| /** | //TODO -- This will be removed | ||||||
|  *  Copyright (C) 2010 Cloud.com, Inc.  All rights reserved. | ///** | ||||||
|  *  | // *  Copyright (C) 2010 Cloud.com, Inc.  All rights reserved. | ||||||
|  * This software is licensed under the GNU General Public License v3 or later. | // *  | ||||||
|  *  | // * This software is licensed under the GNU General Public License v3 or later. | ||||||
|  * It is free software: you can redistribute it and/or modify | // *  | ||||||
|  * it under the terms of the GNU General Public License as published by | // * It is free software: you can redistribute it and/or modify | ||||||
|  * the Free Software Foundation, either version 3 of the License, or any later version. | // * it under the terms of the GNU General Public License as published by | ||||||
|  * This program is distributed in the hope that it will be useful, | // * the Free Software Foundation, either version 3 of the License, or any later version. | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | // * This program is distributed in the hope that it will be useful, | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | // * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  * GNU General Public License for more details. | // * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  *  | // * GNU General Public License for more details. | ||||||
|  * You should have received a copy of the GNU General Public License | // *  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | // * You should have received a copy of the GNU General Public License | ||||||
|  *  | // * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ | // *  | ||||||
| 
 | // */ | ||||||
| package com.cloud.async.executor; | // | ||||||
| 
 | //package com.cloud.async.executor; | ||||||
| import org.apache.log4j.Logger; | // | ||||||
| 
 | //import org.apache.log4j.Logger; | ||||||
| import com.cloud.api.BaseCmd; | // | ||||||
| import com.cloud.async.AsyncJobManager; | //import com.cloud.api.BaseCmd; | ||||||
| import com.cloud.async.AsyncJobResult; | //import com.cloud.async.AsyncJobManager; | ||||||
| import com.cloud.async.AsyncJobVO; | //import com.cloud.async.AsyncJobResult; | ||||||
| import com.cloud.async.BaseAsyncJobExecutor; | //import com.cloud.async.AsyncJobVO; | ||||||
| import com.cloud.serializer.GsonHelper; | //import com.cloud.async.BaseAsyncJobExecutor; | ||||||
| import com.cloud.server.ManagementServer; | //import com.cloud.serializer.GsonHelper; | ||||||
| import com.cloud.service.ServiceOfferingVO; | //import com.cloud.server.ManagementServer; | ||||||
| import com.cloud.storage.VMTemplateVO; | //import com.cloud.service.ServiceOfferingVO; | ||||||
| import com.cloud.user.Account; | //import com.cloud.storage.VMTemplateVO; | ||||||
| import com.cloud.uservm.UserVm; | //import com.cloud.user.Account; | ||||||
| import com.cloud.vm.UserVmVO; | //import com.cloud.uservm.UserVm; | ||||||
| import com.cloud.vm.VMInstanceVO; | //import com.cloud.vm.UserVmVO; | ||||||
| import com.cloud.vm.VmStats; | //import com.cloud.vm.VMInstanceVO; | ||||||
| import com.google.gson.Gson; | //import com.cloud.vm.VmStats; | ||||||
| 
 | //import com.google.gson.Gson; | ||||||
| public class UpgradeVMExecutor extends BaseAsyncJobExecutor { | // | ||||||
|     public static final Logger s_logger = Logger.getLogger(UpgradeVMExecutor.class.getName()); | //public class UpgradeVMExecutor extends BaseAsyncJobExecutor { | ||||||
| 	 | //    public static final Logger s_logger = Logger.getLogger(UpgradeVMExecutor.class.getName()); | ||||||
| 	public boolean execute() { | //	 | ||||||
| 		AsyncJobManager asyncMgr = getAsyncJobMgr(); | //	public boolean execute() { | ||||||
|     	AsyncJobVO job = getJob(); | //		AsyncJobManager asyncMgr = getAsyncJobMgr(); | ||||||
|     	Gson gson = GsonHelper.getBuilder().create(); | //    	AsyncJobVO job = getJob(); | ||||||
| 		 | //    	Gson gson = GsonHelper.getBuilder().create(); | ||||||
| 		if(getSyncSource() == null) { | //		 | ||||||
| 	    	VMOperationParam param = gson.fromJson(job.getCmdInfo(), VMOperationParam.class); | //		if(getSyncSource() == null) { | ||||||
| 	    	asyncMgr.syncAsyncJobExecution(job.getId(), "UserVM", param.getVmId()); | //	    	VMOperationParam param = gson.fromJson(job.getCmdInfo(), VMOperationParam.class); | ||||||
| 	    	 | //	    	asyncMgr.syncAsyncJobExecution(job.getId(), "UserVM", param.getVmId()); | ||||||
| 	    	// always true if it does not have sync-source | //	    	 | ||||||
| 	    	return true; | //	    	// always true if it does not have sync-source | ||||||
| 		} else { | //	    	return true; | ||||||
| 			ManagementServer managementServer = asyncMgr.getExecutorContext().getManagementServer(); | //		} else { | ||||||
| 			UpgradeVMParam param = gson.fromJson(job.getCmdInfo(), UpgradeVMParam.class); | //			ManagementServer managementServer = asyncMgr.getExecutorContext().getManagementServer(); | ||||||
| 			 | //			UpgradeVMParam param = gson.fromJson(job.getCmdInfo(), UpgradeVMParam.class); | ||||||
| 			try { | //			 | ||||||
| 				asyncMgr.updateAsyncJobAttachment(job.getId(), "vm_instance", param.getVmId()); | //			try { | ||||||
| 			    boolean success = managementServer.upgradeVirtualMachine(param.getUserId(),  | //				asyncMgr.updateAsyncJobAttachment(job.getId(), "vm_instance", param.getVmId()); | ||||||
| 			    	param.getVmId(), param.getServiceOfferingId(), param.getEventId()); | //			    boolean success = managementServer.upgradeVirtualMachine(param.getUserId(),  | ||||||
| 	 | //			    	param.getVmId(), param.getServiceOfferingId(), param.getEventId()); | ||||||
| 		        if (success) { | //	 | ||||||
| 		        	//get the upgraded vm to compose the result object | //		        if (success) { | ||||||
| 		        	UserVmVO userVm = managementServer.findUserVMInstanceById(param.getVmId()); | //		        	//get the upgraded vm to compose the result object | ||||||
| 					asyncMgr.completeAsyncJob(getJob().getId(), AsyncJobResult.STATUS_SUCCEEDED, 0,  | //		        	UserVmVO userVm = managementServer.findUserVMInstanceById(param.getVmId()); | ||||||
| 							composeResultObject(userVm, managementServer)); | //					asyncMgr.completeAsyncJob(getJob().getId(), AsyncJobResult.STATUS_SUCCEEDED, 0,  | ||||||
| 					 | //							composeResultObject(userVm, managementServer)); | ||||||
| 		        } else { | //					 | ||||||
| 					asyncMgr.completeAsyncJob(getJob().getId(), AsyncJobResult.STATUS_FAILED,  | //		        } else { | ||||||
| 						BaseCmd.VM_CHANGE_SERVICE_ERROR,  | //					asyncMgr.completeAsyncJob(getJob().getId(), AsyncJobResult.STATUS_FAILED,  | ||||||
| 						composeResultObject(null, managementServer)); | //						BaseCmd.VM_CHANGE_SERVICE_ERROR,  | ||||||
| 		        } | //						composeResultObject(null, managementServer)); | ||||||
| 			} catch(Exception e) { | //		        } | ||||||
| 				s_logger.warn("Unable to upgrade VM " + param.getVmId() + ":" + e.getMessage(), e); | //			} catch(Exception e) { | ||||||
| 				asyncMgr.completeAsyncJob(getJob().getId(), AsyncJobResult.STATUS_FAILED,  | //				s_logger.warn("Unable to upgrade VM " + param.getVmId() + ":" + e.getMessage(), e); | ||||||
| 					BaseCmd.INTERNAL_ERROR,  | //				asyncMgr.completeAsyncJob(getJob().getId(), AsyncJobResult.STATUS_FAILED,  | ||||||
| 					e.getMessage()); | //					BaseCmd.INTERNAL_ERROR,  | ||||||
| 			} | //					e.getMessage()); | ||||||
| 			return true; | //			} | ||||||
| 		} | //			return true; | ||||||
| 	} | //		} | ||||||
| 	 | //	} | ||||||
| 	private VmResultObject composeResultObject(UserVmVO vm, ManagementServer ms) | //	 | ||||||
| 	{ | //	private VmResultObject composeResultObject(UserVmVO vm, ManagementServer ms) | ||||||
| 		if(vm == null) | //	{ | ||||||
| 			return null; | //		if(vm == null) | ||||||
| 		 | //			return null; | ||||||
| 		VmResultObject resultObj = new VmResultObject(); | //		 | ||||||
| 		Account acct = ms.findAccountById(Long.valueOf(vm.getAccountId())); | //		VmResultObject resultObj = new VmResultObject(); | ||||||
| 		resultObj.setAccount(acct.getAccountName()); | //		Account acct = ms.findAccountById(Long.valueOf(vm.getAccountId())); | ||||||
| 		 | //		resultObj.setAccount(acct.getAccountName()); | ||||||
| 		ServiceOfferingVO offering = ms.findServiceOfferingById(vm.getServiceOfferingId()); | //		 | ||||||
| 		resultObj.setCpuSpeed(offering.getSpeed()); | //		ServiceOfferingVO offering = ms.findServiceOfferingById(vm.getServiceOfferingId()); | ||||||
| 		resultObj.setMemory(offering.getRamSize()); | //		resultObj.setCpuSpeed(offering.getSpeed()); | ||||||
| 		if(offering.getDisplayText()!=null) | //		resultObj.setMemory(offering.getRamSize()); | ||||||
| 			resultObj.setServiceOfferingName(offering.getDisplayText()); | //		if(offering.getDisplayText()!=null) | ||||||
| 		else | //			resultObj.setServiceOfferingName(offering.getDisplayText()); | ||||||
| 			resultObj.setServiceOfferingName(offering.getName()); | //		else | ||||||
| 		resultObj.setServiceOfferingId(vm.getServiceOfferingId()); | //			resultObj.setServiceOfferingName(offering.getName()); | ||||||
| 		 | //		resultObj.setServiceOfferingId(vm.getServiceOfferingId()); | ||||||
| 		VmStats vmStats = ms.getVmStatistics(vm.getId()); | //		 | ||||||
| 		if(vmStats != null) | //		VmStats vmStats = ms.getVmStatistics(vm.getId()); | ||||||
| 		{ | //		if(vmStats != null) | ||||||
| 			resultObj.setCpuUsed((long) vmStats.getCPUUtilization()); | //		{ | ||||||
| 			resultObj.setNetworkKbsRead((long) vmStats.getNetworkReadKBs()); | //			resultObj.setCpuUsed((long) vmStats.getCPUUtilization()); | ||||||
| 			resultObj.setNetworkKbsWrite((long) vmStats.getNetworkWriteKBs()); | //			resultObj.setNetworkKbsRead((long) vmStats.getNetworkReadKBs()); | ||||||
| 		} | //			resultObj.setNetworkKbsWrite((long) vmStats.getNetworkWriteKBs()); | ||||||
| 		 | //		} | ||||||
| 		resultObj.setCreated(vm.getCreated()); | //		 | ||||||
| 		resultObj.setDisplayName(vm.getDisplayName()); | //		resultObj.setCreated(vm.getCreated()); | ||||||
| 		resultObj.setDomain(ms.findDomainIdById(acct.getDomainId()).getName()); | //		resultObj.setDisplayName(vm.getDisplayName()); | ||||||
| 		resultObj.setDomainId(acct.getDomainId()); | //		resultObj.setDomain(ms.findDomainIdById(acct.getDomainId()).getName()); | ||||||
| 		resultObj.setHaEnable(vm.isHaEnabled()); | //		resultObj.setDomainId(acct.getDomainId()); | ||||||
| 		if(vm.getHostId() != null) | //		resultObj.setHaEnable(vm.isHaEnabled()); | ||||||
| 		{ | //		if(vm.getHostId() != null) | ||||||
| 			resultObj.setHostId(vm.getHostId()); | //		{ | ||||||
| 			resultObj.setHostName(ms.getHostBy(vm.getHostId()).getName()); | //			resultObj.setHostId(vm.getHostId()); | ||||||
| 		} | //			resultObj.setHostName(ms.getHostBy(vm.getHostId()).getName()); | ||||||
| 		resultObj.setIpAddress(vm.getPrivateIpAddress()); | //		} | ||||||
| 		resultObj.setName(vm.getName()); | //		resultObj.setIpAddress(vm.getPrivateIpAddress()); | ||||||
| 		resultObj.setState(vm.getState().toString()); | //		resultObj.setName(vm.getName()); | ||||||
| 		resultObj.setZoneId(vm.getDataCenterId()); | //		resultObj.setState(vm.getState().toString()); | ||||||
| 		resultObj.setZoneName(ms.findDataCenterById(vm.getDataCenterId()).getName()); | //		resultObj.setZoneId(vm.getDataCenterId()); | ||||||
| 		 | //		resultObj.setZoneName(ms.findDataCenterById(vm.getDataCenterId()).getName()); | ||||||
| 		VMTemplateVO template = ms.findTemplateById(vm.getTemplateId()); | //		 | ||||||
| 		resultObj.setPasswordEnabled(template.getEnablePassword()); | //		VMTemplateVO template = ms.findTemplateById(vm.getTemplateId()); | ||||||
| 		resultObj.setTemplateDisplayText(template.getDisplayText()); | //		resultObj.setPasswordEnabled(template.getEnablePassword()); | ||||||
| 		resultObj.setTemplateId(template.getId()); | //		resultObj.setTemplateDisplayText(template.getDisplayText()); | ||||||
| 		resultObj.setTemplateName(template.getName()); | //		resultObj.setTemplateId(template.getId()); | ||||||
| 		 | //		resultObj.setTemplateName(template.getName()); | ||||||
| 		return resultObj; | //		 | ||||||
| 	} | //		return resultObj; | ||||||
| } | //	} | ||||||
|  | //} | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								server/src/com/cloud/server/ManagementServerImpl.java
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								server/src/com/cloud/server/ManagementServerImpl.java
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user