mirror of
https://github.com/OneUptime/oneuptime
synced 2024-11-21 14:49:07 +00:00
0b10880f58
This refactor updates the TelemetryIngestor and Probe components to initialize telemetry with the correct service name. Previously, the service name was hardcoded or set to a default value, which could lead to inconsistencies and confusion. By using the APP_NAME constant defined in each component, the service name is now dynamically set, ensuring accurate telemetry tracking. Files modified: - TelemetryIngestor/Index.ts - Probe/Index.ts
86 lines
2.6 KiB
TypeScript
86 lines
2.6 KiB
TypeScript
import AliveAPI from "./API/Alive";
|
|
import FluentIngestAPI from "./API/FluentIngest";
|
|
import IncomingRequestAPI from "./API/IncomingRequest";
|
|
import MonitorAPI from "./API/Monitor";
|
|
import OTelIngestAPI from "./API/OTelIngest";
|
|
import Ingestor from "./API/Probe";
|
|
import RegisterAPI from "./API/Register";
|
|
import ServerMonitorAPI from "./API/ServerMonitor";
|
|
import { PromiseVoidFunction } from "Common/Types/FunctionTypes";
|
|
import { ClickhouseAppInstance } from "CommonServer/Infrastructure/ClickhouseDatabase";
|
|
import { PostgresAppInstance } from "CommonServer/Infrastructure/PostgresDatabase";
|
|
import Redis from "CommonServer/Infrastructure/Redis";
|
|
import InfrastructureStatus from "CommonServer/Infrastructure/Status";
|
|
import Express, { ExpressApplication } from "CommonServer/Utils/Express";
|
|
import logger from "CommonServer/Utils/Logger";
|
|
import Realtime from "CommonServer/Utils/Realtime";
|
|
import App from "CommonServer/Utils/StartServer";
|
|
import Telemetry from "CommonServer/Utils/Telemetry";
|
|
import "ejs";
|
|
|
|
const app: ExpressApplication = Express.getExpressApp();
|
|
|
|
const APP_NAME: string = "ingestor";
|
|
|
|
app.use([`/${APP_NAME}`, "/"], AliveAPI);
|
|
app.use([`/${APP_NAME}`, "/"], RegisterAPI);
|
|
app.use([`/${APP_NAME}`, "/"], MonitorAPI);
|
|
app.use([`/${APP_NAME}`, "/"], Ingestor);
|
|
app.use([`/${APP_NAME}`, "/"], IncomingRequestAPI);
|
|
app.use([`/${APP_NAME}`, "/"], OTelIngestAPI);
|
|
app.use([`/${APP_NAME}`, "/"], FluentIngestAPI);
|
|
app.use([`/${APP_NAME}`, "/"], ServerMonitorAPI);
|
|
|
|
const init: PromiseVoidFunction = async (): Promise<void> => {
|
|
try {
|
|
const statusCheck: PromiseVoidFunction = async (): Promise<void> => {
|
|
return await InfrastructureStatus.checkStatus({
|
|
checkClickhouseStatus: true,
|
|
checkPostgresStatus: true,
|
|
checkRedisStatus: true,
|
|
});
|
|
};
|
|
|
|
// Initialize telemetry
|
|
Telemetry.init({
|
|
serviceName: APP_NAME,
|
|
});
|
|
|
|
// init the app
|
|
await App.init({
|
|
appName: APP_NAME,
|
|
statusOptions: {
|
|
liveCheck: statusCheck,
|
|
readyCheck: statusCheck,
|
|
},
|
|
});
|
|
|
|
// connect to the database.
|
|
await PostgresAppInstance.connect(
|
|
PostgresAppInstance.getDatasourceOptions(),
|
|
);
|
|
|
|
// connect redis
|
|
await Redis.connect();
|
|
|
|
await ClickhouseAppInstance.connect(
|
|
ClickhouseAppInstance.getDatasourceOptions(),
|
|
);
|
|
|
|
await Realtime.init();
|
|
|
|
// add default routes
|
|
await App.addDefaultRoutes();
|
|
} catch (err) {
|
|
logger.error("App Init Failed:");
|
|
logger.error(err);
|
|
throw err;
|
|
}
|
|
};
|
|
|
|
init().catch((err: Error) => {
|
|
logger.error(err);
|
|
logger.error("Exiting node process");
|
|
process.exit(1);
|
|
});
|