Implement Baselime monitoring and update error handling

This commit introduces the integration of Baselime for monitoring, accounting for various error scenarios and improved console error logging. Request handling has been updated to assign unique IDs for each request, aiding in tracing/logs. The environment variable key was updated, and the `MonitoringProvider` was nested in the root providers. In the base monitoring service, a function to format errors for logging was added. The provider logic was updated to create a new instance of service for each request, improving memory efficiency.
This commit is contained in:
giancarlo
2024-04-22 18:41:38 +08:00
parent 7e1be64707
commit a074e1ec3b
10 changed files with 172 additions and 36 deletions

View File

@@ -1 +1,2 @@
export * from './error-boundary';
export * from './provider';

View File

@@ -0,0 +1,45 @@
'use client';
import { lazy } from 'react';
import { getMonitoringProvider } from '../get-monitoring-provider';
import { InstrumentationProvider } from '../monitoring-providers.enum';
const BaselimeProvider = lazy(async () => {
const { BaselimeProvider } = await import('@kit/baselime/provider');
return {
default: BaselimeProvider,
};
});
type Config = {
provider: InstrumentationProvider;
providerToken: string;
};
export function MonitoringProvider(
props: React.PropsWithChildren<{ config?: Config }>,
) {
const provider = getMonitoringProvider();
if (!props.config) {
return <>{props.children}</>;
}
switch (provider) {
case InstrumentationProvider.Baselime:
return (
<BaselimeProvider apiKey={props.config?.providerToken} enableWebVitals>
{props.children}
</BaselimeProvider>
);
// sentry does not require a provider
case InstrumentationProvider.Sentry:
return <>{props.children}</>;
default:
return <>{props.children}</>;
}
}

View File

@@ -5,7 +5,7 @@ import { MonitoringService } from '../services/monitoring.service';
const MONITORING = getMonitoringProvider();
let service: MonitoringService;
let serviceFactory: () => MonitoringService;
/**
* @name useMonitoring
@@ -13,22 +13,20 @@ let service: MonitoringService;
* Use Suspense to suspend while loading the service.
*/
export function useMonitoring() {
if (!service) {
if (!serviceFactory) {
throw withMonitoringService();
}
console.log(service);
return service;
return serviceFactory();
}
async function withMonitoringService() {
service = await loadMonitoringService();
serviceFactory = await loadMonitoringService();
}
async function loadMonitoringService() {
async function loadMonitoringService(): Promise<() => MonitoringService> {
if (!MONITORING) {
return new ConsoleMonitoringService();
return Promise.resolve(() => new ConsoleMonitoringService());
}
switch (MONITORING) {
@@ -45,7 +43,9 @@ async function loadMonitoringService() {
}
default: {
throw new Error(`Unknown instrumentation provider: ${MONITORING}`);
throw new Error(
`Unknown instrumentation provider: ${MONITORING as string}`,
);
}
}
}

View File

@@ -6,6 +6,8 @@ export class ConsoleMonitoringService implements MonitoringService {
}
captureException(error: Error) {
console.error(`Caught exception: ${JSON.stringify(error)}`);
console.error(
`[Console Monitoring] Caught exception: ${JSON.stringify(error)}`,
);
}
}