From c5094c3599127f7989a9f96483fe749693498883 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matheus=20Gaudencio=20do=20R=C3=AAgo?= Date: Wed, 4 Dec 2024 21:45:57 -0300 Subject: [PATCH 1/3] Lint. --- .github/workflows/publish.yaml | 2 +- hooks/useDevice.ts | 2 +- runtime/caches/mod.test.ts | 2 +- runtime/routes/invoke.ts | 1 - 4 files changed, 3 insertions(+), 4 deletions(-) diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml index d5e6832fa..01451cac3 100644 --- a/.github/workflows/publish.yaml +++ b/.github/workflows/publish.yaml @@ -102,4 +102,4 @@ jobs: if [ -n "$LATEST" ]; then echo "::set-output name=image_builder_latest::$REGISTRY/$REPOSITORY:$IMAGE_TAG_LATEST" fi - echo "::set-output name=image_builder_commit::$REGISTRY/$REPOSITORY:$IMAGE_TAG_COMMIT" \ No newline at end of file + echo "::set-output name=image_builder_commit::$REGISTRY/$REPOSITORY:$IMAGE_TAG_COMMIT" diff --git a/hooks/useDevice.ts b/hooks/useDevice.ts index ef9ed8fc9..df3bb5b49 100644 --- a/hooks/useDevice.ts +++ b/hooks/useDevice.ts @@ -17,7 +17,7 @@ export const useDevice = (): Device => { } if (!ctx) { - console.warn("Missing context in rendering tree") + console.warn("Missing context in rendering tree"); } return ctx?.device || "desktop"; diff --git a/runtime/caches/mod.test.ts b/runtime/caches/mod.test.ts index 80ce2060b..f3720d571 100644 --- a/runtime/caches/mod.test.ts +++ b/runtime/caches/mod.test.ts @@ -52,7 +52,7 @@ const baseTest = async (cacheStorageUT: CacheStorage) => { const cache = await headersCache(lruCache(cacheStorageUT)).open(CACHE_NAME); const response = () => new Response("Hello, World!", { - headers: { "Content-length": `${MAX_CACHE_SIZE / 2 }` }, + headers: { "Content-length": `${MAX_CACHE_SIZE / 2}` }, }); for (let i = 0; i < 5; i++) { const request = createRequest(i); diff --git a/runtime/routes/invoke.ts b/runtime/routes/invoke.ts index d317634c4..caa16db49 100644 --- a/runtime/routes/invoke.ts +++ b/runtime/routes/invoke.ts @@ -54,7 +54,6 @@ function getParsingStrategy(req: Request): keyof typeof propsParsers | null { return "json"; } - return null; } From c6cacfde8429f0407a44bc356a329c64847d8044 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matheus=20Gaudencio=20do=20R=C3=AAgo?= Date: Wed, 4 Dec 2024 21:46:25 -0300 Subject: [PATCH 2/3] Reduce metrics usage. --- blocks/loader.ts | 9 +++++++-- observability/http.ts | 4 ++-- observability/observe.ts | 12 +++++++----- observability/otel/metrics.ts | 13 ++++++++++++- 4 files changed, 28 insertions(+), 10 deletions(-) diff --git a/blocks/loader.ts b/blocks/loader.ts index 5fd2458f4..af54b48e9 100644 --- a/blocks/loader.ts +++ b/blocks/loader.ts @@ -9,7 +9,10 @@ import type { DecofileProvider } from "../engine/decofile/provider.ts"; import { HttpError } from "../engine/errors.ts"; import type { ResolverMiddlewareContext } from "../engine/middleware.ts"; import { logger } from "../observability/otel/config.ts"; -import { meter } from "../observability/otel/metrics.ts"; +import { + meter, + OTEL_ENABLE_EXTRA_METRICS, +} from "../observability/otel/metrics.ts"; import { caches, ENABLE_LOADER_CACHE } from "../runtime/caches/mod.ts"; import type { HttpContext } from "./handler.ts"; import { @@ -317,7 +320,9 @@ const wrapLoader = ( return await flights.do(request.url, staleWhileRevalidate); } finally { const dimension = { loader, status }; - stats.latency.record(performance.now() - start, dimension); + if (OTEL_ENABLE_EXTRA_METRICS) { + stats.latency.record(performance.now() - start, dimension); + } ctx.monitoring?.currentSpan?.setDesc(status); } }, diff --git a/observability/http.ts b/observability/http.ts index 6659a0140..f4f3ee76c 100644 --- a/observability/http.ts +++ b/observability/http.ts @@ -4,7 +4,7 @@ import { meter } from "./otel/metrics.ts"; const httpDuration = meter.createHistogram("http_request_duration", { description: "http request duration", unit: "ms", - valueType: ValueType.DOUBLE, + valueType: ValueType.INT, }); /** * @returns a end function that when gets called observe the duration of the operation. @@ -12,7 +12,7 @@ const httpDuration = meter.createHistogram("http_request_duration", { export const startObserve = () => { const start = performance.now(); return (method: string, path: string, status: number) => { - httpDuration.record(performance.now() - start, { + httpDuration.record(Math.round(performance.now() - start), { "http.method": method, "http.route": path, "http.response.status": `${status}`, diff --git a/observability/observe.ts b/observability/observe.ts index cdcd9be21..a4c1518ac 100644 --- a/observability/observe.ts +++ b/observability/observe.ts @@ -1,6 +1,6 @@ import { isWrappedError } from "../blocks/loader.ts"; import { ValueType } from "../deps.ts"; -import { meter } from "./otel/metrics.ts"; +import { meter, OTEL_ENABLE_EXTRA_METRICS } from "./otel/metrics.ts"; const operationDuration = meter.createHistogram("block_op_duration", { description: "operation duration", @@ -27,9 +27,11 @@ export const observe = async ( isError = "true"; throw error; } finally { - operationDuration.record(performance.now() - start, { - "operation.name": op, - "operation.is_error": isError, - }); + if (OTEL_ENABLE_EXTRA_METRICS) { + operationDuration.record(performance.now() - start, { + "operation.name": op, + "operation.is_error": isError, + }); + } } }; diff --git a/observability/otel/metrics.ts b/observability/otel/metrics.ts index 0a153d730..e61e9c676 100644 --- a/observability/otel/metrics.ts +++ b/observability/otel/metrics.ts @@ -6,6 +6,17 @@ import { View, } from "../../deps.ts"; import { OTEL_IS_ENABLED, resource } from "./config.ts"; + +export const OTEL_ENABLE_EXTRA_METRICS: boolean = Deno.env.has( + "OTEL_ENABLE_EXTRA_METRICS", +); + +// 2 minutes. We don't need frequent updates here. +export const OTEL_EXPORT_INTERVAL: number = parseInt( + Deno.env.get("OTEL_EXPORT_INTERVAL") ?? "120000", + 10, +); + // a=b,c=d => {a:b, c:d} const headersStringToObject = (headersString: string | undefined | null) => { if (!headersString) { @@ -46,7 +57,7 @@ if (OTEL_IS_ENABLED) { meterProvider.addMetricReader( new PeriodicExportingMetricReader({ exporter: metricExporter, - exportIntervalMillis: 30_000, + exportIntervalMillis: OTEL_EXPORT_INTERVAL, }), ); } From c1367786b1c4de39d6eb330da03e38cdb06c6e04 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matheus=20Gaudencio=20do=20R=C3=AAgo?= Date: Wed, 4 Dec 2024 21:53:20 -0300 Subject: [PATCH 3/3] set export interval to 60s --- observability/otel/metrics.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/observability/otel/metrics.ts b/observability/otel/metrics.ts index e61e9c676..330178e5c 100644 --- a/observability/otel/metrics.ts +++ b/observability/otel/metrics.ts @@ -13,7 +13,7 @@ export const OTEL_ENABLE_EXTRA_METRICS: boolean = Deno.env.has( // 2 minutes. We don't need frequent updates here. export const OTEL_EXPORT_INTERVAL: number = parseInt( - Deno.env.get("OTEL_EXPORT_INTERVAL") ?? "120000", + Deno.env.get("OTEL_EXPORT_INTERVAL") ?? "60000", 10, );