Make redis readiness check recoverable

This commit is contained in:
Ajay
2024-04-19 21:20:40 -04:00
parent cfd7c3d8c4
commit 0f97ce4a49
2 changed files with 8 additions and 9 deletions

View File

@@ -1,19 +1,22 @@
import { Request, Response } from "express";
import { Server } from "http";
import { config } from "../config";
import { getRedisActiveRequests, getRedisStats } from "../utils/redis";
import { getRedisStats } from "../utils/redis";
import { Postgres } from "../databases/Postgres";
import { db } from "../databases/databases";
export async function getReady(req: Request, res: Response, server: Server): Promise<Response> {
const connections = await new Promise((resolve) => server.getConnections((_, count) => resolve(count))) as number;
const redisStats = getRedisStats();
const postgresStats = (db as Postgres).getStats?.();
if (!connections
|| (connections < config.maxConnections
&& (!config.redis || getRedisActiveRequests() < config.redis.maxConnections * 0.8)
&& (!config.redis || getRedisStats().avgReadTime < 2000)
&& (!config.postgres || (db as Postgres).getStats().activeRequests < config.postgres.maxActiveRequests * 0.8))
&& (!config.postgres || (db as Postgres).getStats().avgReadTime < 2000)) {
&& (!config.redis || redisStats.activeRequests < config.redis.maxConnections * 0.8)
&& (!config.redis || redisStats.avgReadTime < 2000 || redisStats.activeRequests < 1)
&& (!config.postgres || postgresStats.activeRequests < config.postgres.maxActiveRequests * 0.8))
&& (!config.postgres || postgresStats.avgReadTime < 2000)) {
return res.sendStatus(200);
} else {
return res.sendStatus(500);