From 12aa30037ec99ea470011e1f2239acce2e46b827 Mon Sep 17 00:00:00 2001 From: Kaushik Iska Date: Fri, 13 Dec 2024 12:45:03 -0800 Subject: [PATCH] add throttling when there is a syncErr (#2356) --- flow/workflows/sync_flow.go | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/flow/workflows/sync_flow.go b/flow/workflows/sync_flow.go index 8b00364dd2..7dce9ffec5 100644 --- a/flow/workflows/sync_flow.go +++ b/flow/workflows/sync_flow.go @@ -79,7 +79,7 @@ func SyncFlowWorkflow( } syncFlowCtx := workflow.WithActivityOptions(syncSessionCtx, workflow.ActivityOptions{ - StartToCloseTimeout: 72 * time.Hour, + StartToCloseTimeout: 7 * 24 * time.Hour, HeartbeatTimeout: time.Minute, WaitForCancellation: true, }) @@ -162,6 +162,15 @@ func SyncFlowWorkflow( } restart := syncErr || workflow.GetInfo(ctx).GetContinueAsNewSuggested() + + if syncErr { + logger.Info("sync flow error, sleeping for 30 seconds...") + err := workflow.Sleep(ctx, 30*time.Second) + if err != nil { + logger.Error("failed to sleep", slog.Any("error", err)) + } + } + if !stop && !syncErr && mustWait { waitSelector.Select(ctx) if restart {