From 24a5e85f87c8f897133dd9b43f6b563e28e7bfde Mon Sep 17 00:00:00 2001 From: Abhishek Pal Date: Thu, 16 Jan 2025 19:44:07 +0530 Subject: [PATCH] Address review comments --- .../smoketest/recon/recon-taskstatus.robot | 30 +++++++++---------- .../impl/OzoneManagerServiceProviderImpl.java | 9 ++---- 2 files changed, 17 insertions(+), 22 deletions(-) diff --git a/hadoop-ozone/dist/src/main/smoketest/recon/recon-taskstatus.robot b/hadoop-ozone/dist/src/main/smoketest/recon/recon-taskstatus.robot index 0b173204349..3b5b011523e 100644 --- a/hadoop-ozone/dist/src/main/smoketest/recon/recon-taskstatus.robot +++ b/hadoop-ozone/dist/src/main/smoketest/recon/recon-taskstatus.robot @@ -24,14 +24,14 @@ Resource ../commonlib.robot Test Timeout 5 minutes *** Variables *** -${BASE_URL} http://recon:9888 +${BASE_URL} http://recon:9888 ${TASK_STATUS_ENDPOINT} ${BASE_URL}/api/v1/task/status ${TRIGGER_SYNC_ENDPOINT} ${BASE_URL}/api/v1/triggerdbsync/om -${TASK_NAME_1} ContainerHealthTask -${TASK_NAME_2} OmDeltaRequest -${BUCKET} testbucket -${VOLUME} testvolume -${KEYPATH} ${VOLUME}/${BUCKET}/testkey +${TASK_NAME_1} ContainerHealthTask +${TASK_NAME_2} OmDeltaRequest +${BUCKET} testbucket +${VOLUME} testvolume +${KEYPATH} ${VOLUME}/${BUCKET}/testkey *** Keywords *** @@ -41,7 +41,7 @@ Kinit as ozone admin Sync OM Data Log To Console Sending CURL request to ${TRIGGER_SYNC_ENDPOINT} ${result} = Execute curl --negotiate -u : -LSs ${TRIGGER_SYNC_ENDPOINT} - Should contain ${result} true # Sync should return true if successful + [return] ${result} Fetch Task Status Log To Console Sending CURL request to ${TASK_STATUS_ENDPOINT} @@ -56,9 +56,10 @@ Prepopulate Data and Trigger OM DB Sync [Documentation] Use Freon to prepopulate the OM DB with data and trigger OM DB sync. Kinit as ozone admin - Freon DFSG n=1000 path=${KEYPATH} + Freon DFSG n=100 path=${KEYPATH} size=100 - Sync OM Data + ${result} = Sync OM Data + Should contain ${result} true # Sync should return true if successful Validate Task Status After Sync [Documentation] Validate that task status is updated after triggering the OM DB sync. @@ -103,13 +104,10 @@ Validate All Tasks Updated After Sync END Validate Sequence number is updated after sync - Log To Console Generating Freon Data - Kinit as ozone admin - Freon DFSG n=100 path=${VOLUME}/${BUCKET}/seqValidationKey + Log To Console Triggering OM DB sync for updates Sync OM Data - - ${tasks} = Fetch Task Status - Should Not Be Empty ${tasks} + ${tasks} = Fetch Task Status + Should Not Be Empty ${tasks} ${om_delta_task_list} = Evaluate [task for task in ${tasks} if task["taskName"] == "OmDeltaRequest"] ${list_length} = Get Length ${om_delta_task_list} @@ -124,4 +122,4 @@ Validate Sequence number is updated after sync IF ${task["isCurrentTaskRunning"]} == 0 Should Be Equal As Integers ${task["lastUpdatedSeqNumber"]} ${om_delta_task_seq_num} END - END \ No newline at end of file + END diff --git a/hadoop-ozone/recon/src/main/java/org/apache/hadoop/ozone/recon/spi/impl/OzoneManagerServiceProviderImpl.java b/hadoop-ozone/recon/src/main/java/org/apache/hadoop/ozone/recon/spi/impl/OzoneManagerServiceProviderImpl.java index d209ab5193c..b0a5e3f7c47 100644 --- a/hadoop-ozone/recon/src/main/java/org/apache/hadoop/ozone/recon/spi/impl/OzoneManagerServiceProviderImpl.java +++ b/hadoop-ozone/recon/src/main/java/org/apache/hadoop/ozone/recon/spi/impl/OzoneManagerServiceProviderImpl.java @@ -478,10 +478,7 @@ void getAndApplyDeltaUpdatesFromOM( inLoopStartSequenceNumber = inLoopLatestSequenceNumber; loopCount++; } - // We might reach loop count limit and so not all updates from RocksDB might be applied. - // Say we have: 1000 updates, each loop we get only 100 updates, loop limit is 5. - // So this will effectively only apply 500 events, even if we are having total 1000 updates/events; - // All subsequent tasks will effectively process only 500 events, till next sync takes place. + omdbUpdatesHandler.setLatestSequenceNumber(getCurrentOMDBSequenceNumber()); LOG.info("Delta updates received from OM : {} loops, {} records", loopCount, getCurrentOMDBSequenceNumber() - fromSequenceNumber @@ -544,8 +541,8 @@ boolean innerGetAndApplyDeltaUpdatesFromOM(long fromSequenceNumber, *
  • Initially it will fetch a snapshot of OM DB.
  • *
  • If we already have data synced it will try to fetch delta updates.
  • *
  • If the sync is completed successfully it will trigger other OM tasks to process events
  • - *
  • If there is any exception while trying to fetch delta updates, it will fall back to snapshot update
  • - *
  • If there is any exception in snapshot sync it will do nothing.
  • + *
  • If there is any exception while trying to fetch delta updates, it will fall back to full snapshot update
  • + *
  • If there is any exception in full snapshot update it will do nothing, and return true.
  • *
  • In case of an interrupt signal (irrespective of delta or snapshot sync), * it will catch and mark the task as interrupted, and return false i.e. sync failed status.
  • *