1 write to _availableNodes
Microsoft.Build (1)
BackEnd\Components\Scheduler\Scheduler.cs (1)
585
_availableNodes
= new Dictionary<int, NodeInfo>(8);
25 references to _availableNodes
Microsoft.Build (25)
BackEnd\Components\Scheduler\Scheduler.cs (25)
535
_availableNodes
[nodeInfo.NodeId] = nodeInfo;
746
HashSet<int> idleNodes = new HashSet<int>(
_availableNodes
.Count);
747
foreach (int availableNodeId in
_availableNodes
.Keys)
772
if (
_availableNodes
.Count > 0)
828
TraceScheduler("Requests scheduled: {0} Unassigned Requests: {1} Blocked Requests: {2} Unblockable Requests: {3} Free Nodes: {4}/{5} Responses: {6}", nodesFreeToDoWorkPriorToScheduling - idleNodes.Count, _schedulingData.UnscheduledRequestsCount, _schedulingData.BlockedRequestsCount, _schedulingData.ReadyRequestsCount, idleNodes.Count,
_availableNodes
.Count, responses.Count);
1078
IEnumerable<int> nodesByConfigurationCountAscending =
_availableNodes
.Keys.OrderBy(x => _schedulingData.GetConfigurationsCountByNode(x, excludeTraversals: true, _configCache));
1218
if (
_availableNodes
[nodeId].CanServiceRequestWithAffinity(nodeAffinity))
1343
Dictionary<int, int> configurationCountsByNode = new Dictionary<int, int>(
_availableNodes
.Count);
1349
foreach (int availableNodeId in
_availableNodes
.Keys)
1355
configurationCountLimit = Math.Max(1, (int)Math.Ceiling(configurationCountLimit * _customSchedulerForSQLConfigurationLimitMultiplier /
_availableNodes
.Count));
1358
List<int> nodesByConfigurationCountAscending = new List<int>(
_availableNodes
.Keys);
1416
bool mustSendConfigurationToNode =
_availableNodes
[nodeId].AssignConfiguration(request.BuildRequest.ConfigurationId);
1507
bool result =
_availableNodes
[nodeId].CanServiceRequestWithAffinity(affinity);
1790
if (!
_availableNodes
[assignedNodeId].CanServiceRequestWithAffinity(GetNodeAffinityForRequest(request)))
1800
existingRequestAffinity = (
_availableNodes
[assignedNodeId].ProviderType == NodeProviderType.InProc) ? NodeAffinity.InProc : NodeAffinity.OutOfProc;
1975
foreach (int nodeId in
_availableNodes
.Keys)
2303
foreach (NodeInfo node in
_availableNodes
.Values)
2402
int[] currentWork = new int[
_availableNodes
.Count];
2409
TimeSpan[] nodeActiveTimes = new TimeSpan[
_availableNodes
.Count];
2410
DateTime[] nodeStartTimes = new DateTime[
_availableNodes
.Count];
2413
Dictionary<int, int> availableNodeIdsToIndex = new Dictionary<int, int>(
_availableNodes
.Count);
2414
int[] indexToAvailableNodeId = new int[
_availableNodes
.Count];
2417
foreach (int availableNodeId in
_availableNodes
.Keys)
2528
loggingService.LogComment(context, MessageImportance.Normal, "NodeUtilizationSummary", utilitzationPercentages.ToString(), (utilizationAverage / (double)
_availableNodes
.Count) * 100);
2724
foreach (int nodeId in
_availableNodes
.Keys)