@nicollasfrazao/liguelead-log-service 1.2.9 → 1.2.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -175,6 +175,8 @@ LogService.info('Log batch', logs); // Array de logs pré-formatados
175
175
  - ✅ **Fallback para armazenamento local** em caso de falha do S3
176
176
  - ✅ **Padrão de serviço estático** - sem necessidade de instanciação
177
177
  - ✅ **Autenticação via IAM Role ARN** (AssumeRole automático, cache, renovação, cross-account)
178
+ - 🛡️ **Resilência de rede** com retry automático e backoff exponencial para conexões Firehose
179
+ - 🔄 **Recovery automático** de erros transitórios como `socket hang up` e `write EPIPE`
178
180
 
179
181
  ## Estrutura dos Arquivos de Log
180
182
 
@@ -238,6 +240,29 @@ Quando `LOG_USE_S3_STORAGE=true`, os logs são enviados para **Kinesis Firehose*
238
240
  - **Endpoint**: Configurável via `LOG_AWS_ENDPOINT` (útil para LocalStack)
239
241
  - **Credenciais**: Via variáveis de ambiente AWS ou perfis IAM
240
242
 
243
+ #### Resilência de Rede (v1.2.10+)
244
+
245
+ O sistema possui **retry automático com backoff exponencial** para resolver erros comuns de rede:
246
+
247
+ **Recursos de Resilência:**
248
+ - 🔄 **Retry Inteligente**: Até 3 tentativas automáticas para erros de rede
249
+ - ⏰ **Backoff Exponencial**: Delay crescente entre tentativas (1s → 2s → 4s + jitter)
250
+ - 🎯 **Detecção Inteligente**: Identifica erros recuperáveis vs permanentes
251
+ - ⚡ **Timeouts Otimizados**: 30 segundos para requisições Firehose
252
+
253
+ **Erros Resolvidos Automaticamente:**
254
+ - `socket hang up` - Conexões TCP interrompidas
255
+ - `write EPIPE` - Escrita em pipe fechado
256
+ - `ECONNRESET` - Conexão resetada pelo peer
257
+ - `ETIMEDOUT` - Timeout de operação
258
+ - `EHOSTUNREACH` / `ENETUNREACH` - Problemas de conectividade
259
+
260
+ **Comportamento:**
261
+ 1. **Tentativa inicial** de envio para Firehose
262
+ 2. **Se falha de rede**: retry automático com backoff exponencial
263
+ 3. **Se falha persistente**: fallback para armazenamento local
264
+ 4. **Logging detalhado** de todas as tentativas para debug
265
+
241
266
  Exemplo de estrutura no S3 via Firehose:
242
267
  ```
243
268
  my-app-logs/
@@ -28,6 +28,14 @@ export declare class LogStorageExternalS3Service extends LogStorageExternalServi
28
28
  * @var {Promise<any> | null}
29
29
  */
30
30
  private credentialsCache;
31
+ /**
32
+ * @var {number}
33
+ */
34
+ private readonly maxRetries;
35
+ /**
36
+ * @var {number}
37
+ */
38
+ private readonly baseDelay;
31
39
  /**
32
40
  * Constructor of the LogStorageS3Service
33
41
  *
@@ -52,6 +60,32 @@ export declare class LogStorageExternalS3Service extends LogStorageExternalServi
52
60
  * @returns {Promise<any>} Fresh credentials object for AWS SDK
53
61
  */
54
62
  private refreshAssumeRoleCredentials;
63
+ /**
64
+ * Sleep for specified milliseconds
65
+ *
66
+ * @param {number} ms - Milliseconds to sleep
67
+ *
68
+ * @returns {Promise<void>}
69
+ */
70
+ private sleep;
71
+ /**
72
+ * Retry function with exponential backoff
73
+ *
74
+ * @param {Function} operation - The operation to retry
75
+ * @param {number} retries - Number of retries remaining
76
+ * @param {number} delay - Current delay in milliseconds
77
+ *
78
+ * @returns {Promise<any>}
79
+ */
80
+ private retryWithBackoff;
81
+ /**
82
+ * Check if error is retryable
83
+ *
84
+ * @param {any} error - The error to check
85
+ *
86
+ * @returns {boolean}
87
+ */
88
+ private isRetryableError;
55
89
  /**
56
90
  * Upload log content to Firehose (which delivers to S3)
57
91
  *
@@ -1 +1 @@
1
- {"version":3,"file":"log.storage.external.s3.service.d.ts","sourceRoot":"","sources":["../../src/services/log.storage.external.s3.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAE3E,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AAEvF,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAI5C;;;;;;;;;GASG;AACH,qBAAa,2BAA4B,SAAQ,yBAAyB;IAExE;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAiB;IAEjC;;OAEG;IACH,OAAO,CAAC,MAAM,CAA6C;IAE3D;;OAEG;IACH,OAAO,CAAC,UAAU,CAAyC;IAE3D;;OAEG;IACH,OAAO,CAAC,gBAAgB,CAA6B;IAErD;;;;OAIG;gBACU,gBAAgB,EAAE,yBAAyB;IA6BxD;;;;OAIG;IACI,SAAS,IAAI,OAAO;IAK3B;;;;OAIG;YACW,wBAAwB;IAqCtC;;;;OAIG;YACW,4BAA4B;IAsC1C;;;;;;;OAOG;YACW,SAAS;IA+BvB;;;;;;;;OAQG;YACW,SAAS;IAgCvB;;;;;;OAMG;IACU,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;CAkBnD"}
1
+ {"version":3,"file":"log.storage.external.s3.service.d.ts","sourceRoot":"","sources":["../../src/services/log.storage.external.s3.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAE3E,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AAEvF,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAI5C;;;;;;;;;GASG;AACH,qBAAa,2BAA4B,SAAQ,yBAAyB;IAExE;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAiB;IAEjC;;OAEG;IACH,OAAO,CAAC,MAAM,CAA6C;IAE3D;;OAEG;IACH,OAAO,CAAC,UAAU,CAAyC;IAE3D;;OAEG;IACH,OAAO,CAAC,gBAAgB,CAA6B;IAErD;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IAExC;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAgB;IAE1C;;;;OAIG;gBACU,gBAAgB,EAAE,yBAAyB;IAgCxD;;;;OAIG;IACI,SAAS,IAAI,OAAO;IAK3B;;;;OAIG;YACW,wBAAwB;IAqCtC;;;;OAIG;YACW,4BAA4B;IA6C1C;;;;;;OAMG;IACH,OAAO,CAAC,KAAK;IAKb;;;;;;;;OAQG;YACW,gBAAgB;IAuC9B;;;;;;OAMG;IACH,OAAO,CAAC,gBAAgB;IA0CxB;;;;;;;OAOG;YACW,SAAS;IAsCvB;;;;;;;;OAQG;YACW,SAAS;IAwCvB;;;;;;OAMG;IACU,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;CA2BnD"}
@@ -33,9 +33,20 @@ class LogStorageExternalS3Service extends log_storage_external_service_1.LogStor
33
33
  * @var {Promise<any> | null}
34
34
  */
35
35
  this.credentialsCache = null;
36
+ /**
37
+ * @var {number}
38
+ */
39
+ this.maxRetries = 3;
40
+ /**
41
+ * @var {number}
42
+ */
43
+ this.baseDelay = 1000;
36
44
  this.config = (0, log_storage_external_s3_config_1.getLogStorageExternalS3Config)();
37
45
  const firehoseConfig = {
38
46
  region: this.config.region,
47
+ requestTimeout: 30000,
48
+ maxAttempts: 3,
49
+ retryMode: 'adaptive'
39
50
  };
40
51
  if (this.config.roleArn) {
41
52
  firehoseConfig.credentials = () => this.getAssumeRoleCredentials();
@@ -109,7 +120,9 @@ class LogStorageExternalS3Service extends log_storage_external_service_1.LogStor
109
120
  DurationSeconds: 3600, // 1 hour
110
121
  });
111
122
  try {
112
- const response = await stsClient.send(command);
123
+ const response = await this.retryWithBackoff(async () => {
124
+ return stsClient.send(command);
125
+ });
113
126
  if (!response.Credentials) {
114
127
  throw new log_error_1.LogError('Failed to retrieve credentials from STS AssumeRole');
115
128
  }
@@ -121,11 +134,96 @@ class LogStorageExternalS3Service extends log_storage_external_service_1.LogStor
121
134
  };
122
135
  }
123
136
  catch (error) {
124
- console.error('Failed to assume role:', error);
137
+ console.error('Failed to assume role after all retries:', {
138
+ error: error.message,
139
+ code: error.code,
140
+ statusCode: error.$metadata?.httpStatusCode,
141
+ retryable: this.isRetryableError(error)
142
+ });
125
143
  this.credentialsCache = null;
126
144
  throw error;
127
145
  }
128
146
  }
147
+ /**
148
+ * Sleep for specified milliseconds
149
+ *
150
+ * @param {number} ms - Milliseconds to sleep
151
+ *
152
+ * @returns {Promise<void>}
153
+ */
154
+ sleep(ms) {
155
+ return new Promise(resolve => setTimeout(resolve, ms));
156
+ }
157
+ /**
158
+ * Retry function with exponential backoff
159
+ *
160
+ * @param {Function} operation - The operation to retry
161
+ * @param {number} retries - Number of retries remaining
162
+ * @param {number} delay - Current delay in milliseconds
163
+ *
164
+ * @returns {Promise<any>}
165
+ */
166
+ async retryWithBackoff(operation, retries = this.maxRetries, delay = this.baseDelay) {
167
+ try {
168
+ return await operation();
169
+ }
170
+ catch (error) {
171
+ if (retries === 0) {
172
+ throw error;
173
+ }
174
+ const isRetryable = this.isRetryableError(error);
175
+ if (!isRetryable) {
176
+ throw error;
177
+ }
178
+ console.warn(`Firehose operation failed, retrying in ${delay}ms. Retries left: ${retries}`, {
179
+ error: error.message,
180
+ code: error.code
181
+ });
182
+ await this.sleep(delay);
183
+ const jitter = Math.random() * 0.1 * delay;
184
+ const nextDelay = delay * 2 + jitter;
185
+ return this.retryWithBackoff(operation, retries - 1, nextDelay);
186
+ }
187
+ }
188
+ /**
189
+ * Check if error is retryable
190
+ *
191
+ * @param {any} error - The error to check
192
+ *
193
+ * @returns {boolean}
194
+ */
195
+ isRetryableError(error) {
196
+ const retryableCodes = [
197
+ 'ECONNRESET',
198
+ 'ECONNREFUSED',
199
+ 'ETIMEDOUT',
200
+ 'EPIPE',
201
+ 'EHOSTUNREACH',
202
+ 'ENETUNREACH',
203
+ 'EAI_AGAIN'
204
+ ];
205
+ const retryableMessages = [
206
+ 'socket hang up',
207
+ 'network timeout',
208
+ 'connection timeout',
209
+ 'write EPIPE',
210
+ 'read ECONNRESET'
211
+ ];
212
+ if (error.code
213
+ && retryableCodes.includes(error.code)) {
214
+ return true;
215
+ }
216
+ if (error.message) {
217
+ const message = error.message.toLowerCase();
218
+ return retryableMessages.some(msg => message.includes(msg));
219
+ }
220
+ if (error.$metadata?.httpStatusCode) {
221
+ const statusCode = error.$metadata.httpStatusCode;
222
+ return statusCode >= 500
223
+ || statusCode === 429;
224
+ }
225
+ return false;
226
+ }
129
227
  /**
130
228
  * Upload log content to Firehose (which delivers to S3)
131
229
  *
@@ -143,14 +241,21 @@ class LogStorageExternalS3Service extends log_storage_external_service_1.LogStor
143
241
  const logEntry = log_service_1.LogService.formatLog(log);
144
242
  return { Data: Buffer.from(logEntry + '\n', 'utf8') };
145
243
  });
146
- await this.firehose.send(new client_firehose_1.PutRecordBatchCommand({
147
- DeliveryStreamName: this.config.firehoseStreamName,
148
- Records: records
149
- }));
244
+ await this.retryWithBackoff(async () => {
245
+ return this.firehose.send(new client_firehose_1.PutRecordBatchCommand({
246
+ DeliveryStreamName: this.config.firehoseStreamName,
247
+ Records: records
248
+ }));
249
+ });
150
250
  }
151
251
  }
152
252
  catch (error) {
153
- console.error(`Failed to upload log to Firehose: ${key}`, error);
253
+ console.error(`Failed to upload log to Firehose after all retries: ${key}`, {
254
+ error: error.message,
255
+ code: error.code,
256
+ statusCode: error.$metadata?.httpStatusCode,
257
+ retryable: this.isRetryableError(error)
258
+ });
154
259
  throw error;
155
260
  }
156
261
  }
@@ -170,7 +275,15 @@ class LogStorageExternalS3Service extends log_storage_external_service_1.LogStor
170
275
  await this.uploadLog(key, data);
171
276
  }
172
277
  catch (error) {
173
- console.error(`Failed to send log to Firehose: ${key}`, error);
278
+ console.error(`Failed to send log to Firehose: ${key}`, {
279
+ error: error.message,
280
+ code: error.code,
281
+ statusCode: error.$metadata?.httpStatusCode,
282
+ requestId: error.$metadata?.requestId,
283
+ retryable: this.isRetryableError(error),
284
+ batchSize: data.length,
285
+ timestamp: new Date().toISOString()
286
+ });
174
287
  throw error;
175
288
  }
176
289
  finally {
@@ -193,7 +306,16 @@ class LogStorageExternalS3Service extends log_storage_external_service_1.LogStor
193
306
  await this.appendLog(combinedFilePath, data);
194
307
  }
195
308
  catch (error) {
196
- console.error('Failed to write log to Firehose/S3 storage:', error);
309
+ console.error('Failed to write log to Firehose/S3 storage:', {
310
+ error: error.message,
311
+ code: error.code,
312
+ statusCode: error.$metadata?.httpStatusCode,
313
+ requestId: error.$metadata?.requestId,
314
+ stream: this.config.firehoseStreamName,
315
+ region: this.config.region,
316
+ retryable: this.isRetryableError(error),
317
+ timestamp: new Date().toISOString()
318
+ });
197
319
  throw error;
198
320
  }
199
321
  }
@@ -1 +1 @@
1
- {"version":3,"file":"log.storage.external.s3.service.js","sourceRoot":"","sources":["../../src/services/log.storage.external.s3.service.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"log.storage.external.s3.service.js","sourceRoot":"","sources":["../../src/services/log.storage.external.s3.service.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nicollasfrazao/liguelead-log-service",
3
- "version": "1.2.9",
3
+ "version": "1.2.11",
4
4
  "description": "A standalone logging service for Express applications with multi-destination storage (local files + S3 via Kinesis Firehose) and comprehensive request tracking using strategy pattern.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",