From 2ec663d80b0e8ea207b61390907d58bb16cb29b8 Mon Sep 17 00:00:00 2001 From: Lars Fagerbakke <162430411+larfeq@users.noreply.github.com> Date: Thu, 5 Dec 2024 15:15:34 +0100 Subject: [PATCH] Added parallelism to sync (#731) - [ ] New feature - [x] Bug fix - [ ] High impact **Description of work:** The sync took too long, I've added parallelism to the two main loops fetching and building data. Set the number of threads to 2 which should double the amount of work being done, ish... **Testing:** - [ ] Can be tested - [ ] Automatic tests created / updated - [ ] Local tests are passing **Checklist:** - [ ] Considered automated tests - [ ] Considered updating specification / documentation - [ ] Considered work items - [ ] Considered security - [ ] Performed developer testing - [x] Checklist finalized / ready for review --- .../Functions/DepartmentResourceOwnerSync.cs | 43 +++++++++++-------- 1 file changed, 25 insertions(+), 18 deletions(-) diff --git a/src/Fusion.Summary.Functions/Functions/DepartmentResourceOwnerSync.cs b/src/Fusion.Summary.Functions/Functions/DepartmentResourceOwnerSync.cs index d00d3445c..c0f8fd315 100644 --- a/src/Fusion.Summary.Functions/Functions/DepartmentResourceOwnerSync.cs +++ b/src/Fusion.Summary.Functions/Functions/DepartmentResourceOwnerSync.cs @@ -84,11 +84,12 @@ public async Task RunAsync( if (_departmentFilter.Length != 0) departments = departments.Where(d => _departmentFilter.Any(df => d.FullDepartment!.Contains(df))); - logger.LogInformation("Found departments {Departments}", JsonConvert.SerializeObject(departments, Formatting.Indented)); - var apiDepartments = new List(); - foreach (var orgUnit in departments) + // Set up parallelism + var threadCount = 2; + + await Parallel.ForEachAsync(departments, new ParallelOptions { MaxDegreeOfParallelism = threadCount }, async (orgUnit, cancellationToken) => { var resourceOwners = orgUnit.Management.Persons .Select(p => Guid.Parse(p.AzureUniqueId)) @@ -102,38 +103,42 @@ public async Task RunAsync( .ToArray(); var recipients = resourceOwners.Concat(delegatedResponsibles).ToArray(); + if (recipients.Length == 0) { logger.LogInformation("Skipping department {Department} as it has no resource owners or delegated responsibles", orgUnit.FullDepartment); - continue; + return; } - apiDepartments.Add(new ApiResourceOwnerDepartment() + lock (apiDepartments) { - DepartmentSapId = orgUnit.SapId!, - FullDepartmentName = orgUnit.FullDepartment!, - ResourceOwnersAzureUniqueId = resourceOwners, - DelegateResourceOwnersAzureUniqueId = delegatedResponsibles - }); - } + apiDepartments.Add(new ApiResourceOwnerDepartment() + { + DepartmentSapId = orgUnit.SapId!, + FullDepartmentName = orgUnit.FullDepartment!, + ResourceOwnersAzureUniqueId = resourceOwners, + DelegateResourceOwnersAzureUniqueId = delegatedResponsibles + }); + } + }); var enqueueTimeForDepartmentMapping = QueueTimeHelper.CalculateEnqueueTime(apiDepartments, _totalBatchTime, logger); logger.LogInformation("Syncing departments {Departments}", JsonConvert.SerializeObject(enqueueTimeForDepartmentMapping, Formatting.Indented)); - - foreach (var department in apiDepartments) + await Parallel.ForEachAsync(apiDepartments, new ParallelOptions { MaxDegreeOfParallelism = threadCount }, async (department, cancellationToken) => { try { - //TODO: Do one batch update instead of individual updates + // TODO: Do one batch update instead of individual updates // Update the database await summaryApiClient.PutDepartmentAsync(department, cancellationToken); } catch (Exception e) { - logger.LogCritical(e, "Failed to PUT department {Department}", JsonConvert.SerializeObject(department, Formatting.Indented)); - continue; + logger.LogCritical(e, "Failed to PUT department {Department}", + JsonConvert.SerializeObject(department, Formatting.Indented)); + return; } try @@ -143,9 +148,11 @@ public async Task RunAsync( } catch (Exception e) { - logger.LogCritical(e, "Failed to send department to queue {Department}", JsonConvert.SerializeObject(department, Formatting.Indented)); + logger.LogCritical(e, "Failed to send department to queue {Department}", + JsonConvert.SerializeObject(department, Formatting.Indented)); } - } + }); + logger.LogInformation("weekly-department-recipients-sync completed"); }