當前位置: 首頁>>代碼示例>>Java>>正文


Java InstanceDiedException類代碼示例

本文整理匯總了Java中org.apache.flink.runtime.instance.InstanceDiedException的典型用法代碼示例。如果您正苦於以下問題:Java InstanceDiedException類的具體用法?Java InstanceDiedException怎麽用?Java InstanceDiedException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


InstanceDiedException類屬於org.apache.flink.runtime.instance包,在下文中一共展示了InstanceDiedException類的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getFreeSlotForTask

import org.apache.flink.runtime.instance.InstanceDiedException; //導入依賴的package包/類
/**
 * Gets a suitable instance to schedule the vertex execution to.
 * <p>
 * NOTE: This method does is not thread-safe, it needs to be synchronized by the caller.
 * 
 * @param vertex The task to run. 
 * @return The instance to run the vertex on, it {@code null}, if no instance is available.
 */
protected SimpleSlot getFreeSlotForTask(ExecutionVertex vertex,
										Iterable<TaskManagerLocation> requestedLocations,
										boolean localOnly) {
	// we need potentially to loop multiple times, because there may be false positives
	// in the set-with-available-instances
	while (true) {
		Pair<Instance, Locality> instanceLocalityPair = findInstance(requestedLocations, localOnly);

		if (instanceLocalityPair == null){
			return null;
		}

		Instance instanceToUse = instanceLocalityPair.getLeft();
		Locality locality = instanceLocalityPair.getRight();

		try {
			SimpleSlot slot = instanceToUse.allocateSimpleSlot();
			
			// if the instance has further available slots, re-add it to the set of available resources.
			if (instanceToUse.hasResourcesAvailable()) {
				this.instancesWithAvailableResources.put(instanceToUse.getTaskManagerID(), instanceToUse);
			}
			
			if (slot != null) {
				slot.setLocality(locality);
				return slot;
			}
		}
		catch (InstanceDiedException e) {
			// the instance died it has not yet been propagated to this scheduler
			// remove the instance from the set of available instances
			removeInstance(instanceToUse);
		}
		
		// if we failed to get a slot, fall through the loop
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:46,代碼來源:Scheduler.java

示例2: getNewSlotForSharingGroup

import org.apache.flink.runtime.instance.InstanceDiedException; //導入依賴的package包/類
/**
 * Tries to allocate a new slot for a vertex that is part of a slot sharing group. If one
 * of the instances has a slot available, the method will allocate it as a shared slot, add that
 * shared slot to the sharing group, and allocate a simple slot from that shared slot.
 * 
 * <p>This method will try to allocate a slot from one of the local instances, and fall back to
 * non-local instances, if permitted.</p>
 * 
 * @param vertex The vertex to allocate the slot for.
 * @param requestedLocations The locations that are considered local. May be null or empty, if the
 *                           vertex has no location preferences.
 * @param groupAssignment The slot sharing group of the vertex. Mandatory parameter.
 * @param constraint The co-location constraint of the vertex. May be null.
 * @param localOnly Flag to indicate if non-local choices are acceptable.
 * 
 * @return A sub-slot for the given vertex, or {@code null}, if no slot is available.
 */
protected SimpleSlot getNewSlotForSharingGroup(ExecutionVertex vertex,
												Iterable<TaskManagerLocation> requestedLocations,
												SlotSharingGroupAssignment groupAssignment,
												CoLocationConstraint constraint,
												boolean localOnly)
{
	// we need potentially to loop multiple times, because there may be false positives
	// in the set-with-available-instances
	while (true) {
		Pair<Instance, Locality> instanceLocalityPair = findInstance(requestedLocations, localOnly);
		
		if (instanceLocalityPair == null) {
			// nothing is available
			return null;
		}

		final Instance instanceToUse = instanceLocalityPair.getLeft();
		final Locality locality = instanceLocalityPair.getRight();

		try {
			JobVertexID groupID = vertex.getJobvertexId();
			
			// allocate a shared slot from the instance
			SharedSlot sharedSlot = instanceToUse.allocateSharedSlot(groupAssignment);

			// if the instance has further available slots, re-add it to the set of available resources.
			if (instanceToUse.hasResourcesAvailable()) {
				this.instancesWithAvailableResources.put(instanceToUse.getTaskManagerID(), instanceToUse);
			}

			if (sharedSlot != null) {
				// add the shared slot to the assignment group and allocate a sub-slot
				SimpleSlot slot = constraint == null ?
						groupAssignment.addSharedSlotAndAllocateSubSlot(sharedSlot, locality, groupID) :
						groupAssignment.addSharedSlotAndAllocateSubSlot(sharedSlot, locality, constraint);

				if (slot != null) {
					return slot;
				}
				else {
					// could not add and allocate the sub-slot, so release shared slot
					sharedSlot.releaseSlot(new FlinkException("Could not allocate sub-slot."));
				}
			}
		}
		catch (InstanceDiedException e) {
			// the instance died it has not yet been propagated to this scheduler
			// remove the instance from the set of available instances
			removeInstance(instanceToUse);
		}

		// if we failed to get a slot, fall through the loop
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:72,代碼來源:Scheduler.java

示例3: handleNewSlot

import org.apache.flink.runtime.instance.InstanceDiedException; //導入依賴的package包/類
private void handleNewSlot() {
	
	synchronized (globalLock) {
		Instance instance = this.newlyAvailableInstances.poll();
		if (instance == null || !instance.hasResourcesAvailable()) {
			// someone else took it
			return;
		}
		
		QueuedTask queued = taskQueue.peek();
		
		// the slot was properly released, we can allocate a new one from that instance
		
		if (queued != null) {
			ScheduledUnit task = queued.getTask();
			ExecutionVertex vertex = task.getTaskToExecute().getVertex();
			
			try {
				SimpleSlot newSlot = instance.allocateSimpleSlot();
				if (newSlot != null) {
					
					// success, remove from the task queue and notify the future
					taskQueue.poll();
					if (queued.getFuture() != null) {
						try {
							queued.getFuture().complete(newSlot);
						}
						catch (Throwable t) {
							LOG.error("Error calling allocation future for task " + vertex.getTaskNameWithSubtaskIndex(), t);
							task.getTaskToExecute().fail(t);
						}
					}
				}
			}
			catch (InstanceDiedException e) {
				if (LOG.isDebugEnabled()) {
					LOG.debug("Instance " + instance + " was marked dead asynchronously.");
				}
				
				removeInstance(instance);
			}
		}
		else {
			this.instancesWithAvailableResources.put(instance.getTaskManagerID(), instance);
		}
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:48,代碼來源:Scheduler.java


注:本文中的org.apache.flink.runtime.instance.InstanceDiedException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。