perf: add server timings

This commit is contained in:
FireMasterK 2021-01-30 20:38:52 +05:30
parent 6d8ccdb728
commit ec247f5bce
No known key found for this signature in database
GPG key ID: 8DFF5DD33E93DB58

View file

@ -30,19 +30,22 @@ public class Main {
routes.get("/webhooks/pubsub", (req, res) -> { routes.get("/webhooks/pubsub", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, query.parameters().get("hub.challenge").get(0), 200, "private"); return writeResponse(res, query.parameters().get("hub.challenge").get(0), 200, "private", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.post("/webhooks/pubsub", (req, res) -> { routes.post("/webhooks/pubsub", (req, res) -> {
long start = System.nanoTime();
try { try {
req.receive().asInputStream().subscribe(in -> { req.receive().asInputStream().subscribe(in -> {
try { try {
@ -57,145 +60,155 @@ public class Main {
e.printStackTrace(); e.printStackTrace();
} }
}); });
return writeResponse(res, "ok", 200, "private"); return writeResponse(res, "ok", 200, "private", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/sponsors/{videoId}", (req, res) -> { routes.get("/sponsors/{videoId}", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, SponsorBlockUtils.getSponsors(req.param("videoId"), return writeResponse(res, SponsorBlockUtils.getSponsors(req.param("videoId"),
query.parameters().get("category").get(0)), 200, "public, max-age=3600"); query.parameters().get("category").get(0)), 200, "public, max-age=3600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/streams/{videoId}", (req, res) -> { routes.get("/streams/{videoId}", (req, res) -> {
long start = System.nanoTime();
try { try {
// The stream links are valid for 6 hours. // The stream links are valid for 6 hours.
return writeResponse(res, ResponseHelper.streamsResponse(req.param("videoId")), 200, return writeResponse(res, ResponseHelper.streamsResponse(req.param("videoId")), 200,
"public, s-maxage=21540"); "public, s-maxage=21540", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/channels/{channelId}", (req, res) -> { routes.get("/channels/{channelId}", (req, res) -> {
long start = System.nanoTime();
try { try {
return writeResponse(res, ResponseHelper.channelResponse(req.param("channelId")), 200, return writeResponse(res, ResponseHelper.channelResponse(req.param("channelId")), 200,
"public, max-age=600"); "public, max-age=600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/nextpage/channels/{channelId}", (req, res) -> { routes.get("/nextpage/channels/{channelId}", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, ResponseHelper.channelPageResponse(req.param("channelId"), return writeResponse(res, ResponseHelper.channelPageResponse(req.param("channelId"),
query.parameters().get("url").get(0)), 200, "public, max-age=3600"); query.parameters().get("url").get(0)), 200, "public, max-age=3600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/playlists/{playlistId}", (req, res) -> { routes.get("/playlists/{playlistId}", (req, res) -> {
long start = System.nanoTime();
try { try {
return writeResponse(res, ResponseHelper.playlistResponse(req.param("playlistId")), 200, return writeResponse(res, ResponseHelper.playlistResponse(req.param("playlistId")), 200,
"public, max-age=600"); "public, max-age=600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/nextpage/playlists/{playlistId}", (req, res) -> { routes.get("/nextpage/playlists/{playlistId}", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, ResponseHelper.playlistPageResponse(req.param("playlistId"), return writeResponse(res, ResponseHelper.playlistPageResponse(req.param("playlistId"),
query.parameters().get("url").get(0)), 200, "public, max-age=3600"); query.parameters().get("url").get(0)), 200, "public, max-age=3600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/suggestions", (req, res) -> { routes.get("/suggestions", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, return writeResponse(res,
ResponseHelper.suggestionsResponse(query.parameters().get("query").get(0)), 200, ResponseHelper.suggestionsResponse(query.parameters().get("query").get(0)), 200,
"public, max-age=600"); "public, max-age=600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/search", (req, res) -> { routes.get("/search", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, ResponseHelper.searchResponse(query.parameters().get("q").get(0)), 200, return writeResponse(res, ResponseHelper.searchResponse(query.parameters().get("q").get(0)), 200,
"public, max-age=600"); "public, max-age=600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/nextpage/search", (req, res) -> { routes.get("/nextpage/search", (req, res) -> {
long start = System.nanoTime();
QueryStringDecoder query = new QueryStringDecoder(req.uri()); QueryStringDecoder query = new QueryStringDecoder(req.uri());
try { try {
return writeResponse(res, return writeResponse(res,
ResponseHelper.searchPageResponse(query.parameters().get("q").get(0), ResponseHelper.searchPageResponse(query.parameters().get("q").get(0),
query.parameters().get("url").get(0), query.parameters().get("id").get(0)), query.parameters().get("url").get(0), query.parameters().get("id").get(0)),
200, "public, max-age=3600"); 200, "public, max-age=3600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
routes.get("/trending", (req, res) -> { routes.get("/trending", (req, res) -> {
long start = System.nanoTime();
try { try {
return writeResponse(res, ResponseHelper.trendingResponse(), 200, "public, max-age=3600"); return writeResponse(res, ResponseHelper.trendingResponse(), 200, "public, max-age=3600", start);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private"); return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
} }
}); });
@ -205,14 +218,16 @@ public class Main {
Thread.sleep(Long.MAX_VALUE); Thread.sleep(Long.MAX_VALUE);
} }
public static NettyOutbound writeResponse(HttpServerResponse res, String resp, int code, String cache) { public static NettyOutbound writeResponse(HttpServerResponse res, String resp, int code, String cache, long time) {
return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache) return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache)
.addHeader("Server-Timing", "app;dur=" + (System.nanoTime() - time) / 1000000.0)
.send(ByteBufFlux.fromString(Flux.just(resp), java.nio.charset.StandardCharsets.UTF_8, .send(ByteBufFlux.fromString(Flux.just(resp), java.nio.charset.StandardCharsets.UTF_8,
ByteBufAllocator.DEFAULT)); ByteBufAllocator.DEFAULT));
} }
public static NettyOutbound writeResponse(HttpServerResponse res, byte[] resp, int code, String cache) { public static NettyOutbound writeResponse(HttpServerResponse res, byte[] resp, int code, String cache, long time) {
return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache) return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache)
.addHeader("Server-Timing", "app;dur=" + (System.nanoTime() - time) / 1000000.0)
.sendByteArray(Flux.just(resp)); .sendByteArray(Flux.just(resp));
} }