Class IsolatedPool
- java.lang.Object
- 
- org.apache.storm.scheduler.multitenant.NodePool
- 
- org.apache.storm.scheduler.multitenant.IsolatedPool
 
 
- 
 public class IsolatedPool extends NodePool A pool of machines that can be used to run isolated topologies.
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class org.apache.storm.scheduler.multitenant.NodePoolNodePool.NodeAndSlotCounts, NodePool.RoundRobinSlotScheduler
 
- 
 - 
Field Summary- 
Fields inherited from class org.apache.storm.scheduler.multitenant.NodePoolcluster, nodeIdToNode
 
- 
 - 
Constructor SummaryConstructors Constructor Description IsolatedPool(int maxNodes)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddTopology(TopologyDetails td)Add a topology to the pool.booleancanAdd(TopologyDetails td)Check if this topology can be added to this pool.NodePool.NodeAndSlotCountsgetNodeAndSlotCountIfSlotsWereTaken(int slotsNeeded)Get the number of nodes and slots this would provide to get the slots needed.intnodesAvailable()Get the number of available nodes.voidscheduleAsNeeded(NodePool... lesserPools)Reschedule any topologies as needed.intslotsAvailable()Get number of available slots.Collection<Node>takeNodes(int nodesNeeded)Take up to nodesNeeded from this pool.Collection<Node>takeNodesBySlots(int slotsNeeded)Take nodes from this pool that can fulfill possibly up to the slotsNeeded.StringtoString()- 
Methods inherited from class org.apache.storm.scheduler.multitenant.NodePoolgetNodeCountIfSlotsWereTaken, init, nodesAvailable, slotsAvailable, takeNodes, takeNodesBySlot
 
- 
 
- 
- 
- 
Method Detail- 
addTopologypublic void addTopology(TopologyDetails td) Description copied from class:NodePoolAdd a topology to the pool.- Specified by:
- addTopologyin class- NodePool
- Parameters:
- td- the topology to add
 
 - 
canAddpublic boolean canAdd(TopologyDetails td) Description copied from class:NodePoolCheck if this topology can be added to this pool.
 - 
scheduleAsNeededpublic void scheduleAsNeeded(NodePool... lesserPools) Description copied from class:NodePoolReschedule any topologies as needed.- Specified by:
- scheduleAsNeededin class- NodePool
- Parameters:
- lesserPools- pools that may be used to steal nodes from.
 
 - 
takeNodespublic Collection<Node> takeNodes(int nodesNeeded) Description copied from class:NodePoolTake up to nodesNeeded from this pool.
 - 
nodesAvailablepublic int nodesAvailable() Description copied from class:NodePoolGet the number of available nodes.- Specified by:
- nodesAvailablein class- NodePool
- Returns:
- the number of nodes that are available to be taken
 
 - 
slotsAvailablepublic int slotsAvailable() Description copied from class:NodePoolGet number of available slots.- Specified by:
- slotsAvailablein class- NodePool
- Returns:
- the number of slots that are available to be taken
 
 - 
takeNodesBySlotspublic Collection<Node> takeNodesBySlots(int slotsNeeded) Description copied from class:NodePoolTake nodes from this pool that can fulfill possibly up to the slotsNeeded.- Specified by:
- takeNodesBySlotsin class- NodePool
- Parameters:
- slotsNeeded- the number of slots that are needed.
- Returns:
- a Collection of nodes with the removed nodes in it. This may be empty, but should not be null.
 
 - 
getNodeAndSlotCountIfSlotsWereTakenpublic NodePool.NodeAndSlotCounts getNodeAndSlotCountIfSlotsWereTaken(int slotsNeeded) Description copied from class:NodePoolGet the number of nodes and slots this would provide to get the slots needed.- Specified by:
- getNodeAndSlotCountIfSlotsWereTakenin class- NodePool
- Parameters:
- slotsNeeded- the number of slots needed
- Returns:
- the number of nodes and slots that would be returned.
 
 
- 
 
-