mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Merge remote-tracking branch 'origin/4.18'
This commit is contained in:
		
						commit
						c3aeba1f4a
					
				| @ -42,6 +42,7 @@ import javax.inject.Inject; | ||||
| import javax.naming.ConfigurationException; | ||||
| 
 | ||||
| import com.cloud.exception.InvalidParameterValueException; | ||||
| import com.cloud.user.Account; | ||||
| import com.cloud.utils.Pair; | ||||
| import org.apache.cloudstack.agent.directdownload.DirectDownloadAnswer; | ||||
| import org.apache.cloudstack.agent.directdownload.DirectDownloadCommand; | ||||
| @ -329,6 +330,8 @@ public class DirectDownloadManagerImpl extends ManagerBase implements DirectDown | ||||
|         Long[] hostsToRetry = getHostsToRetryOn(host, storagePoolVO); | ||||
|         int hostIndex = 0; | ||||
|         Answer answer = null; | ||||
|         String answerDetails = ""; | ||||
|         String errorDetails = ""; | ||||
|         Long hostToSendDownloadCmd = hostsToRetry[hostIndex]; | ||||
|         boolean continueRetrying = true; | ||||
|         while (!downloaded && retry > 0 && continueRetrying) { | ||||
| @ -349,6 +352,7 @@ public class DirectDownloadManagerImpl extends ManagerBase implements DirectDown | ||||
|                 if (answer != null) { | ||||
|                     DirectDownloadAnswer ans = (DirectDownloadAnswer)answer; | ||||
|                     downloaded = answer.getResult(); | ||||
|                     answerDetails = answer.getDetails(); | ||||
|                     continueRetrying = ans.isRetryOnOtherHosts(); | ||||
|                 } | ||||
|                 hostToSendDownloadCmd = hostsToRetry[(hostIndex + 1) % hostsToRetry.length]; | ||||
| @ -362,7 +366,13 @@ public class DirectDownloadManagerImpl extends ManagerBase implements DirectDown | ||||
|         } | ||||
|         if (!downloaded) { | ||||
|             logUsageEvent(template, poolId); | ||||
|             throw new CloudRuntimeException("Template " + template.getId() + " could not be downloaded on pool " + poolId + ", failing after trying on several hosts"); | ||||
|             if (!answerDetails.isEmpty()){ | ||||
|                 Account caller = CallContext.current().getCallingAccount(); | ||||
|                 if (caller != null && caller.getType() == Account.Type.ADMIN){ | ||||
|                     errorDetails = String.format(" Details: %s", answerDetails); | ||||
|                 } | ||||
|             } | ||||
|             throw new CloudRuntimeException(String.format("Template %d could not be downloaded on pool %d, failing after trying on several hosts%s", template.getId(), poolId, errorDetails)); | ||||
|         } | ||||
|         return answer; | ||||
|     } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user