@genkit-ai/core
Version:
Genkit AI framework core libraries.
91 lines • 3.12 kB
JavaScript
import { NodeSDK } from "@opentelemetry/sdk-node";
import {
BatchSpanProcessor,
SimpleSpanProcessor
} from "@opentelemetry/sdk-trace-base";
import { logger } from "./logging.js";
import {
TraceServerExporter,
setTelemetryServerUrl
} from "./tracing/exporter.js";
import { isDevEnv } from "./utils.js";
export * from "./tracing/exporter.js";
export * from "./tracing/instrumentation.js";
export * from "./tracing/processor.js";
export * from "./tracing/types.js";
let telemetrySDK = null;
let nodeOtelConfig = null;
const instrumentationKey = "__GENKIT_TELEMETRY_INSTRUMENTED";
async function ensureBasicTelemetryInstrumentation() {
await checkFirebaseMonitoringAutoInit();
if (global[instrumentationKey]) {
return await global[instrumentationKey];
}
await enableTelemetry({});
}
async function checkFirebaseMonitoringAutoInit() {
if (!global[instrumentationKey] && process.env.ENABLE_FIREBASE_MONITORING === "true") {
try {
const firebaseModule = await require("@genkit-ai/firebase");
firebaseModule.enableFirebaseTelemetry();
} catch (e) {
logger.warn(
"It looks like you're trying to enable firebase monitoring, but haven't installed the firebase plugin. Please run `npm i --save @genkit-ai/firebase` and redeploy."
);
}
}
}
async function enableTelemetry(telemetryConfig) {
if (process.env.GENKIT_TELEMETRY_SERVER) {
setTelemetryServerUrl(process.env.GENKIT_TELEMETRY_SERVER);
}
global[instrumentationKey] = telemetryConfig instanceof Promise ? telemetryConfig : Promise.resolve();
telemetryConfig = telemetryConfig instanceof Promise ? await telemetryConfig : telemetryConfig;
nodeOtelConfig = telemetryConfig || {};
const processors = [createTelemetryServerProcessor()];
if (nodeOtelConfig.traceExporter) {
throw new Error("Please specify spanProcessors instead.");
}
if (nodeOtelConfig.spanProcessors) {
processors.push(...nodeOtelConfig.spanProcessors);
}
if (nodeOtelConfig.spanProcessor) {
processors.push(nodeOtelConfig.spanProcessor);
delete nodeOtelConfig.spanProcessor;
}
nodeOtelConfig.spanProcessors = processors;
telemetrySDK = new NodeSDK(nodeOtelConfig);
telemetrySDK.start();
process.on("SIGTERM", async () => await cleanUpTracing());
}
async function cleanUpTracing() {
if (!telemetrySDK) {
return;
}
await maybeFlushMetrics();
await telemetrySDK.shutdown();
logger.debug("OpenTelemetry SDK shut down.");
telemetrySDK = null;
}
function createTelemetryServerProcessor() {
const exporter = new TraceServerExporter();
return isDevEnv() ? new SimpleSpanProcessor(exporter) : new BatchSpanProcessor(exporter);
}
function maybeFlushMetrics() {
if (nodeOtelConfig?.metricReader) {
return nodeOtelConfig.metricReader.forceFlush();
}
return Promise.resolve();
}
async function flushTracing() {
if (nodeOtelConfig?.spanProcessors) {
await Promise.all(nodeOtelConfig.spanProcessors.map((p) => p.forceFlush()));
}
}
export {
cleanUpTracing,
enableTelemetry,
ensureBasicTelemetryInstrumentation,
flushTracing
};
//# sourceMappingURL=tracing.mjs.map