From c6b1f8480917a1235e6768c162efb72c891ebd9b Mon Sep 17 00:00:00 2001 From: Mikel Alejo Barcina Ribera Date: Wed, 4 Dec 2024 12:03:50 +0100 Subject: [PATCH] feature: enhance logging for the Kessel assets migration Having traces will allow us to know what is exactly happening when we run the migrations. RHCLOUD-35454 --- .../auth/rbac/workspace/WorkspaceUtils.java | 2 ++ .../kessel/KesselAssetsMigrationService.java | 22 +++++++++++++++++-- .../src/main/resources/application.properties | 1 + 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/backend/src/main/java/com/redhat/cloud/notifications/auth/rbac/workspace/WorkspaceUtils.java b/backend/src/main/java/com/redhat/cloud/notifications/auth/rbac/workspace/WorkspaceUtils.java index aa6e971a3c..87d9325534 100644 --- a/backend/src/main/java/com/redhat/cloud/notifications/auth/rbac/workspace/WorkspaceUtils.java +++ b/backend/src/main/java/com/redhat/cloud/notifications/auth/rbac/workspace/WorkspaceUtils.java @@ -102,6 +102,8 @@ public UUID getDefaultWorkspaceId(final String orgId) { throw new UnauthorizedException(); } + Log.debugf("[org_id: %s][workspace_id: %s] Fetched default workspace from RBAC", orgId, rbacWorkspace.id()); + return rbacWorkspace.id(); } } diff --git a/backend/src/main/java/com/redhat/cloud/notifications/routers/internal/kessel/KesselAssetsMigrationService.java b/backend/src/main/java/com/redhat/cloud/notifications/routers/internal/kessel/KesselAssetsMigrationService.java index 6c0b3a796c..1e15708b3b 100644 --- a/backend/src/main/java/com/redhat/cloud/notifications/routers/internal/kessel/KesselAssetsMigrationService.java +++ b/backend/src/main/java/com/redhat/cloud/notifications/routers/internal/kessel/KesselAssetsMigrationService.java @@ -59,46 +59,64 @@ public class KesselAssetsMigrationService { @Path("/kessel/migrate-assets") @POST public void migrateAssets() { + Log.info("Kessel assets' migration begins"); + int fetchedEndpointsSize = 0; int offset = 0; + int traceLoops = 0; do { + Log.tracef("[loops: %s] Loops", traceLoops); + final List fetchedEndpoints = this.endpointRepository.getNonSystemEndpointsWithLimitAndOffset(this.backendConfig.getKesselMigrationBatchSize(), offset); + Log.debugf("[offset: %s][first_integration: %s][last_integration: %s] Fetched %s integrations", offset, fetchedEndpoints.getFirst().getId(), fetchedEndpoints.getLast().getId(), fetchedEndpoints.size()); // If for some reason we have fetched full pages from the database // all the time, the last one might be empty, so there is no need // to attempt calling Kessel. if (fetchedEndpoints.isEmpty()) { + Log.trace("Breaking the do-while loop because the size of the fetched integrations is zero"); break; } final CreateTuplesRequest request = this.createTuplesRequest(fetchedEndpoints); + Log.tracef("Generated a \"CreateTuplesRequest\": %s", request); + final int finalOffset = offset; this.relationTuplesClient.createTuples(request, new StreamObserver<>() { @Override public void onNext(final CreateTuplesResponse createTuplesResponse) { + Log.trace("Calling onNext"); + Log.infof("[offset: %s][first_integration: %s][last_integration: %s] Sent % integrations to Kessel", finalOffset, fetchedEndpoints.getFirst().getId(), fetchedEndpoints.getLast().getId(), fetchedEndpoints.size()); } @Override public void onError(final Throwable throwable) { - Log.errorf(throwable, "[offset: %s][first_integration: %s][last_integration: %s] Unable to send batch of tuples to Kessel with offset %s", finalOffset, fetchedEndpoints.getFirst().getId(), fetchedEndpoints.getLast().getId()); + Log.trace("Calling onError"); + Log.errorf(throwable, "[offset: %s][first_integration: %s][last_integration: %s] Unable to send batch of tuples to Kessel with offset", finalOffset, fetchedEndpoints.getFirst().getId(), fetchedEndpoints.getLast().getId()); } @Override public void onCompleted() { + Log.trace("Calling onCompleted"); Log.infof("[offset: %s][first_integration: %s][last_integration: %s] Sent % integrations to Kessel", finalOffset, fetchedEndpoints.getFirst().getId(), fetchedEndpoints.getLast().getId(), fetchedEndpoints.size()); } }); fetchedEndpointsSize = fetchedEndpoints.size(); offset += fetchedEndpoints.size(); + traceLoops += 1; + + Log.tracef("[fetchedEndpointsSize: %s][kesselMigrationBatchSize: %s][offset: %s] do-while loop condition", fetchedEndpointsSize, offset, this.backendConfig.getKesselMigrationBatchSize()); } while (fetchedEndpointsSize == this.backendConfig.getKesselMigrationBatchSize()); - Log.infof("Finished migrating integrations to the Kessel inventory"); + Log.info("Finished migrating integrations to the Kessel inventory"); } @Path("/kessel/migrate-assets/async") @POST public void migrateAssetsAsync() { + Log.info("Kessel assets' migration begins"); + final int limit = this.backendConfig.getKesselMigrationBatchSize(); final AtomicInteger offsetContainer = new AtomicInteger(0); diff --git a/backend/src/main/resources/application.properties b/backend/src/main/resources/application.properties index eba27ba848..f5cb4953f6 100644 --- a/backend/src/main/resources/application.properties +++ b/backend/src/main/resources/application.properties @@ -106,6 +106,7 @@ quarkus.unleash.active=false quarkus.unleash.url=http://localhost:4242 # Kessel +quarkus.log.category."com.redhat.cloud.notifications.routers.internal.kessel.KesselAssetsMigrationService".min-level=TRACE quarkus.log.category."com.redhat.cloud.notifications.auth.kessel".min-level=TRACE inventory-api.authn.client.id=insights-notifications