Skip to content

Commit 847f1bb

Browse files
authored
Merge pull request #499 from mchangrh/getStatus-redis
add redis process time to getStatus
2 parents ada3221 + 0e3eeec commit 847f1bb

File tree

2 files changed

+34
-6
lines changed

2 files changed

+34
-6
lines changed

src/routes/getStatus.ts

Lines changed: 22 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -3,25 +3,41 @@ import { Logger } from "../utils/logger";
33
import { Request, Response } from "express";
44
import os from "os";
55
import redis from "../utils/redis";
6+
import { promiseOrTimeout } from "../utils/promise";
67

78
export async function getStatus(req: Request, res: Response): Promise<Response> {
89
const startTime = Date.now();
910
let value = req.params.value as string[] | string;
1011
value = Array.isArray(value) ? value[0] : value;
12+
let processTime, redisProcessTime = -1;
1113
try {
12-
const dbVersion = (await db.prepare("get", "SELECT key, value FROM config where key = ?", ["version"])).value;
14+
const dbVersion = await promiseOrTimeout(db.prepare("get", "SELECT key, value FROM config where key = ?", ["version"]), 5000)
15+
.then(e => {
16+
processTime = Date.now() - startTime;
17+
return e.value;
18+
})
19+
.catch(e => {
20+
Logger.error(`status: SQL query timed out: ${e}`);
21+
return -1;
22+
});
1323
let statusRequests: unknown = 0;
14-
try {
15-
const numberRequests = await redis.increment("statusRequest");
16-
statusRequests = numberRequests?.[0];
17-
} catch (error) { } // eslint-disable-line no-empty
24+
const numberRequests = await promiseOrTimeout(redis.increment("statusRequest"), 5000)
25+
.then(e => {
26+
redisProcessTime = Date.now() - startTime;
27+
return e;
28+
}).catch(e => {
29+
Logger.error(`status: redis increment timed out ${e}`);
30+
return [-1];
31+
});
32+
statusRequests = numberRequests?.[0];
1833

1934
const statusValues: Record<string, any> = {
2035
uptime: process.uptime(),
2136
commit: (global as any).HEADCOMMIT || "unknown",
2237
db: Number(dbVersion),
2338
startTime,
24-
processTime: Date.now() - startTime,
39+
processTime,
40+
redisProcessTime,
2541
loadavg: os.loadavg().slice(1), // only return 5 & 15 minute load average
2642
statusRequests,
2743
hostname: os.hostname()

test/cases/getStatus.ts

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -110,4 +110,16 @@ describe("getStatus", () => {
110110
})
111111
.catch(err => done(err));
112112
});
113+
114+
it("Should be able to get redis latency", function (done) {
115+
if (!config.redis?.enabled) this.skip();
116+
client.get(endpoint)
117+
.then(res => {
118+
assert.strictEqual(res.status, 200);
119+
const data = res.data;
120+
assert.ok(data.redisProcessTime >= 0);
121+
done();
122+
})
123+
.catch(err => done(err));
124+
});
113125
});

0 commit comments

Comments
 (0)