You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have detected an issue related to the retry policy and the handling of batches during the synchronization process. Specifically, the problem occurs when an error is encountered during the "applying changes" step. Here's a summary of the issue:
Current Behavior
When changes are being applied and an error occurs, the downloaded batches are typically deleted automatically by the following code:
// If the option to clean the folder is set && the message allows cleaning (it won't allow cleaning if the batch is an error batch)if(this.Options.CleanFolder){// Before cleaning, check if we are not applying changes from a snapshot directoryvarcleanFolder=awaitthis.InternalCanCleanFolderAsync(scopeInfo.Name,context.Parameters,message.Changes,cancellationToken,progress).ConfigureAwait(false);// Clear the changes because we don't need them anymoreif(cleanFolder){this.Logger.LogInformation($@"[InternalApplyChangesAsync]. Cleaning directory {{directoryName}}.",message.Changes.DirectoryName);message.Changes.TryRemoveDirectory();}}
However, if a retry is initiated after an error, only the last batch is uploaded again. This can lead to issues such as foreign key constraint failures if the batch table has dependencies and those dependencies were not applied because the related batch does not exist. As a result, the error message may not accurately reflect the root cause. In cases where the last table has no dependencies, the synchronization may succeed even though previous tables were not properly applied.
Suggested Solutions
To address this issue, I suggest the following possible solutions:
Separate Step for Applying Data: Introduce a separate step specifically for applying data. If an error occurs, the system should retry until the maximum retry count is reached. If the maximum retry count is reached without success, the batch files should be deleted.
Retry from the First Batch: When an error occurs, the retry process should start from the first batch. This would involve re-downloading all the data. While this approach could lead to performance issues, it would ensure that all data is applied correctly.
Batch Folder Management: Create a batch folder based on the client ID and avoid deleting it until the next synchronization. This way, the previous batch can be either deleted or retained based on the outcome of the next sync, helping to keep the disk space managed efficiently.
These improvements would help to ensure that data is applied correctly and that errors are handled more effectively during synchronization.
The text was updated successfully, but these errors were encountered:
Hi,
I have detected an issue related to the retry policy and the handling of batches during the synchronization process. Specifically, the problem occurs when an error is encountered during the "applying changes" step. Here's a summary of the issue:
Current Behavior
When changes are being applied and an error occurs, the downloaded batches are typically deleted automatically by the following code:
However, if a retry is initiated after an error, only the last batch is uploaded again. This can lead to issues such as foreign key constraint failures if the batch table has dependencies and those dependencies were not applied because the related batch does not exist. As a result, the error message may not accurately reflect the root cause. In cases where the last table has no dependencies, the synchronization may succeed even though previous tables were not properly applied.
Suggested Solutions
To address this issue, I suggest the following possible solutions:
Separate Step for Applying Data: Introduce a separate step specifically for applying data. If an error occurs, the system should retry until the maximum retry count is reached. If the maximum retry count is reached without success, the batch files should be deleted.
Retry from the First Batch: When an error occurs, the retry process should start from the first batch. This would involve re-downloading all the data. While this approach could lead to performance issues, it would ensure that all data is applied correctly.
Batch Folder Management: Create a batch folder based on the client ID and avoid deleting it until the next synchronization. This way, the previous batch can be either deleted or retained based on the outcome of the next sync, helping to keep the disk space managed efficiently.
These improvements would help to ensure that data is applied correctly and that errors are handled more effectively during synchronization.
The text was updated successfully, but these errors were encountered: