From 70223675f7d969acef67adde6ca6cc6ca2bbebbc Mon Sep 17 00:00:00 2001 From: Robert Kenny Date: Thu, 25 Jan 2024 14:02:09 +0000 Subject: [PATCH 1/3] add requests api healthcheck endpoint --- .../src/main/scala/weco/api/requests/RequestsApi.scala | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/requests/src/main/scala/weco/api/requests/RequestsApi.scala b/requests/src/main/scala/weco/api/requests/RequestsApi.scala index eae7572d31..9f76ebb964 100644 --- a/requests/src/main/scala/weco/api/requests/RequestsApi.scala +++ b/requests/src/main/scala/weco/api/requests/RequestsApi.scala @@ -50,7 +50,14 @@ class RequestsApi( } ~ get { lookupRequests(userIdentifier) } - } + }, + pathPrefix("management") { + concat(path("healthcheck") { + get { + complete("message" -> "ok") + } + }) + } ) } From 2bc03242dd9e750ef731b901192d04a8707b3624 Mon Sep 17 00:00:00 2001 From: Robert Kenny Date: Thu, 25 Jan 2024 14:57:47 +0000 Subject: [PATCH 2/3] Add healthcheck controller & endpoint This change adds a healthcheck endpoint to provide to a loadbalancer for the purposes of checking application health at deployment and under normal service. --- concepts/src/app.ts | 2 ++ concepts/src/controllers/healthcheck.ts | 16 ++++++++++++++++ concepts/src/controllers/index.ts | 3 ++- 3 files changed, 20 insertions(+), 1 deletion(-) create mode 100644 concepts/src/controllers/healthcheck.ts diff --git a/concepts/src/app.ts b/concepts/src/app.ts index 78e8fcc030..3df62b6209 100644 --- a/concepts/src/app.ts +++ b/concepts/src/app.ts @@ -5,6 +5,7 @@ import { conceptController, conceptsController, errorHandler, + healthcheckController, } from "./controllers"; import { Config } from "../config"; import { Clients } from "./types"; @@ -16,6 +17,7 @@ const createApp = (clients: Clients, config: Config) => { app.get("/concepts", conceptsController(clients, config)); app.get("/concepts/:id", conceptController(clients, config)); + app.get("/management/healthcheck", healthcheckController(config)); app.use(errorHandler); diff --git a/concepts/src/controllers/healthcheck.ts b/concepts/src/controllers/healthcheck.ts new file mode 100644 index 0000000000..b1c5c6e415 --- /dev/null +++ b/concepts/src/controllers/healthcheck.ts @@ -0,0 +1,16 @@ +import { RequestHandler } from "express"; +import asyncHandler from "express-async-handler"; +import { Config } from "../../config"; + +type PathParams = { id: string }; + +const healthcheckController = (config: Config): RequestHandler => { + return asyncHandler(async (req, res) => { + res.status(200).json({ + status: "ok", + config, + }); + }); +}; + +export default healthcheckController; diff --git a/concepts/src/controllers/index.ts b/concepts/src/controllers/index.ts index a187840e9c..2f9bf279c8 100644 --- a/concepts/src/controllers/index.ts +++ b/concepts/src/controllers/index.ts @@ -1,5 +1,6 @@ import conceptController from "./concept"; import conceptsController from "./concepts"; +import healthcheckController from "./healthcheck"; export { errorHandler } from "./error"; -export { conceptController, conceptsController }; +export { conceptController, conceptsController, healthcheckController }; From a06ba85328cba62e8dc2c4ef4fb0cad97cc8535d Mon Sep 17 00:00:00 2001 From: Robert Kenny Date: Thu, 25 Jan 2024 15:29:47 +0000 Subject: [PATCH 3/3] remove optional tcp healthcheck, no longer used --- terraform/modules/service/target_group.tf | 20 ++++---------------- terraform/modules/service/variables.tf | 7 ------- 2 files changed, 4 insertions(+), 23 deletions(-) diff --git a/terraform/modules/service/target_group.tf b/terraform/modules/service/target_group.tf index 9a7e611663..88e85ed346 100644 --- a/terraform/modules/service/target_group.tf +++ b/terraform/modules/service/target_group.tf @@ -15,22 +15,10 @@ resource "aws_lb_target_group" "tcp" { # updated service. Reducing this parameter to 90s makes deployments faster. deregistration_delay = 90 - dynamic "health_check" { - for_each = var.tcp_healthcheck == false ? toset([]) : toset([1]) - - content { - protocol = "TCP" - } - } - - dynamic "health_check" { - for_each = var.tcp_healthcheck == true ? toset([]) : toset([1]) - - content { - protocol = "HTTP" - path = var.healthcheck_path - matcher = "200" - } + health_check { + protocol = "HTTP" + path = var.healthcheck_path + matcher = "200" } } diff --git a/terraform/modules/service/variables.tf b/terraform/modules/service/variables.tf index 54ffe9fdf9..8c6b8e9aad 100644 --- a/terraform/modules/service/variables.tf +++ b/terraform/modules/service/variables.tf @@ -73,14 +73,7 @@ variable "app_memory" { type = number } -variable "tcp_healthcheck" { - # TODO: Remove this when all services use HTTP healthcheck - type = bool - default = true -} - variable "healthcheck_path" { - # Note: this is only used when tcp_healthcheck is set to false type = string default = "/management/healthcheck" }