From 92b18a229a576063786b0edc34154046dff30ad4 Mon Sep 17 00:00:00 2001 From: Cody Born Date: Fri, 26 Jul 2024 20:27:13 +0200 Subject: [PATCH] Fix S3 clock skew --- lib/providers/circuit-breaker/s3.ts | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/lib/providers/circuit-breaker/s3.ts b/lib/providers/circuit-breaker/s3.ts index 02c1d6e..ea7766c 100644 --- a/lib/providers/circuit-breaker/s3.ts +++ b/lib/providers/circuit-breaker/s3.ts @@ -12,7 +12,6 @@ export class S3CircuitBreakerConfigurationProvider implements CircuitBreakerConf private log: Logger; private fillers: CircuitBreakerConfiguration[]; private lastUpdatedTimestamp: number; - private client: S3Client; allow_list: Set; // try to refetch endpoints every 5 mins @@ -28,11 +27,6 @@ export class S3CircuitBreakerConfigurationProvider implements CircuitBreakerConf this.log = _log.child({ quoter: 'S3CircuitBreakerConfigurationProvider' }); this.fillers = []; this.lastUpdatedTimestamp = Date.now(); - this.client = new S3Client({ - requestHandler: new NodeHttpHandler({ - requestTimeout: 500, - }), - }); this.allow_list = _allow_list; } @@ -79,7 +73,12 @@ export class S3CircuitBreakerConfigurationProvider implements CircuitBreakerConf async fetchConfigurations(): Promise { try { - const s3Res = await this.client.send( + const client = new S3Client({ + requestHandler: new NodeHttpHandler({ + requestTimeout: 500, + }), + }); + const s3Res = await client.send( new GetObjectCommand({ Bucket: this.bucket, Key: this.key, @@ -110,7 +109,12 @@ export class S3CircuitBreakerConfigurationProvider implements CircuitBreakerConf enabled: rate < S3CircuitBreakerConfigurationProvider.FILL_RATE_THRESHOLD, }); } - await this.client.send( + const client = new S3Client({ + requestHandler: new NodeHttpHandler({ + requestTimeout: 500, + }), + }); + await client.send( new PutObjectCommand({ Bucket: this.bucket, Key: this.key,