mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	CLOUDSTACK-9100: ISO.CREATE/TEMPLATE.CREATE event missing for usage_event by template sync thread
This commit is contained in:
		
							parent
							
								
									339355594c
								
							
						
					
					
						commit
						c3353257ef
					
				| @ -27,6 +27,12 @@ import java.util.Set; | |||||||
| 
 | 
 | ||||||
| import javax.inject.Inject; | import javax.inject.Inject; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.configuration.Resource; | ||||||
|  | import com.cloud.event.EventTypes; | ||||||
|  | import com.cloud.event.UsageEventUtils; | ||||||
|  | import org.apache.cloudstack.engine.subsystem.api.storage.Scope; | ||||||
|  | import org.apache.cloudstack.framework.messagebus.MessageBus; | ||||||
|  | import org.apache.cloudstack.framework.messagebus.PublishScope; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.CopyCommandResult; | import org.apache.cloudstack.engine.subsystem.api.storage.CopyCommandResult; | ||||||
| @ -137,6 +143,8 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|     @Inject |     @Inject | ||||||
|     StorageCacheManager _cacheMgr; |     StorageCacheManager _cacheMgr; | ||||||
|     @Inject |     @Inject | ||||||
|  |     MessageBus _messageBus; | ||||||
|  |     @Inject | ||||||
|     ImageStoreDetailsUtil imageStoreDetailsUtil; |     ImageStoreDetailsUtil imageStoreDetailsUtil; | ||||||
| 
 | 
 | ||||||
|     class TemplateOpContext<T> extends AsyncRpcContext<T> { |     class TemplateOpContext<T> extends AsyncRpcContext<T> { | ||||||
| @ -355,6 +363,16 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|                                         toBeDownloaded.add(tmplt); |                                         toBeDownloaded.add(tmplt); | ||||||
|                                     } |                                     } | ||||||
|                                 } else { |                                 } else { | ||||||
|  |                                     if(tmpltStore.getDownloadState() != Status.DOWNLOADED) { | ||||||
|  |                                         String etype = EventTypes.EVENT_TEMPLATE_CREATE; | ||||||
|  |                                         if (tmplt.getFormat() == ImageFormat.ISO) { | ||||||
|  |                                             etype = EventTypes.EVENT_ISO_CREATE; | ||||||
|  |                                         } | ||||||
|  | 
 | ||||||
|  |                                         UsageEventUtils.publishUsageEvent(etype, tmplt.getAccountId(), zoneId, tmplt.getId(), tmplt.getName(), null, null, | ||||||
|  |                                                 tmpltInfo.getPhysicalSize(), tmpltInfo.getSize(), VirtualMachineTemplate.class.getName(), tmplt.getUuid()); | ||||||
|  |                                     } | ||||||
|  | 
 | ||||||
|                                     tmpltStore.setDownloadPercent(100); |                                     tmpltStore.setDownloadPercent(100); | ||||||
|                                     tmpltStore.setDownloadState(Status.DOWNLOADED); |                                     tmpltStore.setDownloadState(Status.DOWNLOADED); | ||||||
|                                     tmpltStore.setState(ObjectInDataStoreStateMachine.State.Ready); |                                     tmpltStore.setState(ObjectInDataStoreStateMachine.State.Ready); | ||||||
| @ -405,6 +423,14 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|                                 tmlpt.setSize(tmpltInfo.getSize()); |                                 tmlpt.setSize(tmpltInfo.getSize()); | ||||||
|                                 _templateDao.update(tmplt.getId(), tmlpt); |                                 _templateDao.update(tmplt.getId(), tmlpt); | ||||||
|                                 associateTemplateToZone(tmplt.getId(), zoneId); |                                 associateTemplateToZone(tmplt.getId(), zoneId); | ||||||
|  | 
 | ||||||
|  |                                 String etype = EventTypes.EVENT_TEMPLATE_CREATE; | ||||||
|  |                                 if (tmplt.getFormat() == ImageFormat.ISO) { | ||||||
|  |                                     etype = EventTypes.EVENT_ISO_CREATE; | ||||||
|  |                                 } | ||||||
|  | 
 | ||||||
|  |                                 UsageEventUtils.publishUsageEvent(etype, tmplt.getAccountId(), zoneId, tmplt.getId(), tmplt.getName(), null, null, | ||||||
|  |                                         tmpltInfo.getPhysicalSize(), tmpltInfo.getSize(), VirtualMachineTemplate.class.getName(), tmplt.getUuid()); | ||||||
|                             } |                             } | ||||||
|                         } else if (tmplt.getState() == VirtualMachineTemplate.State.NotUploaded || tmplt.getState() == VirtualMachineTemplate.State.UploadInProgress) { |                         } else if (tmplt.getState() == VirtualMachineTemplate.State.NotUploaded || tmplt.getState() == VirtualMachineTemplate.State.UploadInProgress) { | ||||||
|                             s_logger.info("Template Sync did not find " + uniqueName + " on image store " + storeId + " uploaded using SSVM, marking it as failed"); |                             s_logger.info("Template Sync did not find " + uniqueName + " on image store " + storeId + " uploaded using SSVM, marking it as failed"); | ||||||
| @ -474,8 +500,12 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|                             if (availHypers.contains(tmplt.getHypervisorType())) { |                             if (availHypers.contains(tmplt.getHypervisorType())) { | ||||||
|                                 s_logger.info("Downloading template " + tmplt.getUniqueName() + " to image store " + store.getName()); |                                 s_logger.info("Downloading template " + tmplt.getUniqueName() + " to image store " + store.getName()); | ||||||
|                                 associateTemplateToZone(tmplt.getId(), zoneId); |                                 associateTemplateToZone(tmplt.getId(), zoneId); | ||||||
|                                 TemplateInfo tmpl = _templateFactory.getTemplate(tmplt.getId(), DataStoreRole.Image); |                                 TemplateInfo tmpl = _templateFactory.getTemplate(tmplt.getId(), store); | ||||||
|                                 createTemplateAsync(tmpl, store, null); |                                 TemplateOpContext<TemplateApiResult> context = new TemplateOpContext<>(null,(TemplateObject)tmpl, null); | ||||||
|  |                                 AsyncCallbackDispatcher<TemplateServiceImpl, TemplateApiResult> caller = AsyncCallbackDispatcher.create(this); | ||||||
|  |                                 caller.setCallback(caller.getTarget().createTemplateAsyncCallBack(null, null)); | ||||||
|  |                                 caller.setContext(context); | ||||||
|  |                                 createTemplateAsync(tmpl, store, caller); | ||||||
|                             } else { |                             } else { | ||||||
|                                 s_logger.info("Skip downloading template " + tmplt.getUniqueName() + " since current data center does not have hypervisor " + |                                 s_logger.info("Skip downloading template " + tmplt.getUniqueName() + " since current data center does not have hypervisor " + | ||||||
|                                         tmplt.getHypervisorType().toString()); |                                         tmplt.getHypervisorType().toString()); | ||||||
| @ -566,6 +596,47 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     protected Void createTemplateAsyncCallBack(AsyncCallbackDispatcher<TemplateServiceImpl, TemplateApiResult> callback, | ||||||
|  |                                                TemplateOpContext<TemplateApiResult> context) { | ||||||
|  |         TemplateInfo template = context.template; | ||||||
|  |         TemplateApiResult result = callback.getResult(); | ||||||
|  |         if (result.isSuccess()) { | ||||||
|  |             VMTemplateVO tmplt = _templateDao.findById(template.getId()); | ||||||
|  |             // need to grant permission for public templates | ||||||
|  |             if (tmplt.isPublicTemplate()) { | ||||||
|  |                 _messageBus.publish(null, TemplateManager.MESSAGE_REGISTER_PUBLIC_TEMPLATE_EVENT, PublishScope.LOCAL, tmplt.getId()); | ||||||
|  |             } | ||||||
|  |             long accountId = tmplt.getAccountId(); | ||||||
|  |             if (template.getSize() != null) { | ||||||
|  |                 // publish usage event | ||||||
|  |                 String etype = EventTypes.EVENT_TEMPLATE_CREATE; | ||||||
|  |                 if (tmplt.getFormat() == ImageFormat.ISO) { | ||||||
|  |                     etype = EventTypes.EVENT_ISO_CREATE; | ||||||
|  |                 } | ||||||
|  |                 // get physical size from template_store_ref table | ||||||
|  |                 long physicalSize = 0; | ||||||
|  |                 DataStore ds = template.getDataStore(); | ||||||
|  |                 TemplateDataStoreVO tmpltStore = _vmTemplateStoreDao.findByStoreTemplate(ds.getId(), template.getId()); | ||||||
|  |                 if (tmpltStore != null) { | ||||||
|  |                     physicalSize = tmpltStore.getPhysicalSize(); | ||||||
|  |                 } else { | ||||||
|  |                     s_logger.warn("No entry found in template_store_ref for template id: " + template.getId() + " and image store id: " + ds.getId() + | ||||||
|  |                             " at the end of registering template!"); | ||||||
|  |                 } | ||||||
|  |                 Scope dsScope = ds.getScope(); | ||||||
|  |                 if (dsScope.getScopeId() != null) { | ||||||
|  |                     UsageEventUtils.publishUsageEvent(etype, template.getAccountId(), dsScope.getScopeId(), template.getId(), template.getName(), null, null, | ||||||
|  |                             physicalSize, template.getSize(), VirtualMachineTemplate.class.getName(), template.getUuid()); | ||||||
|  |                 } else { | ||||||
|  |                     s_logger.warn("Zone scope image store " + ds.getId() + " has a null scope id"); | ||||||
|  |                 } | ||||||
|  |                 _resourceLimitMgr.incrementResourceCount(accountId, Resource.ResourceType.secondary_storage, template.getSize()); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     private Map<String, TemplateProp> listTemplate(DataStore ssStore) { |     private Map<String, TemplateProp> listTemplate(DataStore ssStore) { | ||||||
|         ListTemplateCommand cmd = new ListTemplateCommand(ssStore.getTO(), imageStoreDetailsUtil.getNfsVersion(ssStore.getId())); |         ListTemplateCommand cmd = new ListTemplateCommand(ssStore.getTO(), imageStoreDetailsUtil.getNfsVersion(ssStore.getId())); | ||||||
|         EndPoint ep = _epSelector.select(ssStore); |         EndPoint ep = _epSelector.select(ssStore); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user