Class NodeSorterHostProximity
- All Implemented Interfaces:
- INodeSorter
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceinterface for calculating the number of existing executors scheduled on a object (rack or node).
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Clusterprotected final BaseResourceAwareStrategy.NodeSortTypeprotected TopologyDetails
- 
Constructor SummaryConstructorsConstructorDescriptionNodeSorterHostProximity(Cluster cluster, TopologyDetails topologyDetails) NodeSorterHostProximity(Cluster cluster, TopologyDetails topologyDetails, BaseResourceAwareStrategy.NodeSortType nodeSortType) Initialize for the default implementation node sorting.
- 
Method SummaryModifier and TypeMethodDescriptionRacks are sorted by two criteria.hostnameToNodes(String hostname) hostname to Ids.makeHostToNodeIds(List<String> hosts) voidprepare(ExecutorDetails exec) Prepare for node sorting.protected Iterable<ObjectResourcesItem>sortObjectResources(ObjectResourcesSummary resourcesSummary, ExecutorDetails exec, NodeSorterHostProximity.ExistingScheduleFunc existingScheduleFunc) Scheduling usessortAllNodes()which eventually calls this method whose behavior can be altered by settingnodeSortType.
- 
Field Details- 
nodeSortType
- 
cluster
- 
topologyDetails
- 
greyListedSupervisorIds
- 
favoredNodeIds
- 
unFavoredNodeIds
 
- 
- 
Constructor Details- 
NodeSorterHostProximity
- 
NodeSorterHostProximitypublic NodeSorterHostProximity(Cluster cluster, TopologyDetails topologyDetails, BaseResourceAwareStrategy.NodeSortType nodeSortType) Initialize for the default implementation node sorting.- Parameters:
- cluster- for which nodes will be sorted.
- topologyDetails- the topology to sort for.
- nodeSortType- type of sorting to be applied to object resource collection- BaseResourceAwareStrategy.NodeSortType.
 
 
- 
- 
Method Details- 
getRackIdToHosts
- 
prepareDescription copied from interface:INodeSorterPrepare for node sorting. This method must be called beforeINodeSorter.getSortedRacks()andINodeSorter.sortAllNodes().- Specified by:
- preparein interface- INodeSorter
- Parameters:
- exec- optional, may be null.
 
- 
sortObjectResourcesprotected Iterable<ObjectResourcesItem> sortObjectResources(ObjectResourcesSummary resourcesSummary, ExecutorDetails exec, NodeSorterHostProximity.ExistingScheduleFunc existingScheduleFunc) Scheduling usessortAllNodes()which eventually calls this method whose behavior can be altered by settingnodeSortType.- Parameters:
- resourcesSummary- contains all individual- ObjectResourcesItemas well as cumulative stats
- exec- executor for which the sorting is done
- existingScheduleFunc- a function to get existing executors already scheduled on this object
- Returns:
- an Iterableof sortedObjectResourcesItem
 
- 
makeHostToNodeIds
- 
sortAllNodes- Specified by:
- sortAllNodesin interface- INodeSorter
 
- 
getScheduledExecCntByRackId
- 
getSortedRacksRacks are sorted by two criteria.1) the number executors of the topology that needs to be scheduled is already on the rack in descending order. The reasoning to sort based on criterion 1 is so we schedule the rest of a topology on the same rack as the existing executors of the topology. 2) the subordinate/subservient resource availability percentage of a rack in descending order We calculate the resource availability percentage by dividing the resource availability on the rack by the resource availability of the entire cluster By doing this calculation, racks that have exhausted or little of one of the resources mentioned above will be ranked after racks that have more balanced resource availability. So we will be less likely to pick a rack that have a lot of one resource but a low amount of another. - Specified by:
- getSortedRacksin interface- INodeSorter
- Returns:
- an iterable of sorted racks
 
- 
hostnameToNodeshostname to Ids.- Parameters:
- hostname- the hostname.
- Returns:
- the ids n that node.
 
 
-