From a34c35efaf41532e7453c90c31bd2366af657490 Mon Sep 17 00:00:00 2001 From: Gavin Frazar Date: Mon, 7 Oct 2024 17:59:20 -0700 Subject: [PATCH 1/2] add retries for postgres auto user proc creation --- lib/srv/db/postgres/users.go | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/lib/srv/db/postgres/users.go b/lib/srv/db/postgres/users.go index 4b6a4ee0e7c27..9426fc2fe429d 100644 --- a/lib/srv/db/postgres/users.go +++ b/lib/srv/db/postgres/users.go @@ -81,7 +81,11 @@ func (e *Engine) ActivateUser(ctx context.Context, sessionCtx *common.Session) e return trace.Wrap(err) } - if err := e.createProcedures(ctx, sessionCtx, conn, []string{activateProcName, deactivateProcName}); err != nil { + err = withRetry(ctx, logger, func() error { + err := e.createProcedures(ctx, sessionCtx, conn, []string{activateProcName, deactivateProcName}) + return trace.Wrap(err) + }) + if err != nil { return trace.Wrap(err) } @@ -295,12 +299,16 @@ func (e *Engine) DeactivateUser(ctx context.Context, sessionCtx *common.Session) } defer conn.Close(ctx) - if err := e.createProcedures(ctx, sessionCtx, conn, []string{deactivateProcName}); err != nil { + logger := e.Log.With("user", sessionCtx.DatabaseUser) + logger.InfoContext(ctx, "Deactivating PostgreSQL user.") + err = withRetry(ctx, logger, func() error { + err := e.createProcedures(ctx, sessionCtx, conn, []string{deactivateProcName}) return trace.Wrap(err) + }) + if err != nil { + return trace.NewAggregate(errRemove, trace.Wrap(err)) } - logger := e.Log.With("user", sessionCtx.DatabaseUser) - logger.InfoContext(ctx, "Deactivating PostgreSQL user.") err = withRetry(ctx, logger, func() error { return trace.Wrap(e.callProcedure(ctx, sessionCtx, conn, deactivateProcName, sessionCtx.DatabaseUser)) }) From 150c914886a7cfb9b70bccce887396627ac973be Mon Sep 17 00:00:00 2001 From: Gavin Frazar Date: Mon, 7 Oct 2024 18:01:58 -0700 Subject: [PATCH 2/2] bump the conn timeout up --- e2e/aws/databases_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/e2e/aws/databases_test.go b/e2e/aws/databases_test.go index a03fabf2df509..e7395ca8e01ce 100644 --- a/e2e/aws/databases_test.go +++ b/e2e/aws/databases_test.go @@ -113,7 +113,7 @@ func awsDBDiscoveryUnmatched(t *testing.T) { } const ( - waitForConnTimeout = 60 * time.Second + waitForConnTimeout = 90 * time.Second connRetryTick = 10 * time.Second )