From 49be7fac294e9dc6b0a6f7031a2da581ebbd2d4f Mon Sep 17 00:00:00 2001 From: EarthlingDavey <15802017+EarthlingDavey@users.noreply.github.com> Date: Wed, 30 Oct 2024 19:37:17 +0000 Subject: [PATCH 1/4] Make nginx readiness endpoint dependant on a working socket to fpm --- deploy/config/local/nginx/server.conf | 17 ++++++++++++++++- public/metrics/service.php | 1 + public/metrics/socket.php | 3 +++ 3 files changed, 20 insertions(+), 1 deletion(-) create mode 100644 public/metrics/socket.php diff --git a/deploy/config/local/nginx/server.conf b/deploy/config/local/nginx/server.conf index be1c5c58f..8d0076ceb 100644 --- a/deploy/config/local/nginx/server.conf +++ b/deploy/config/local/nginx/server.conf @@ -116,6 +116,11 @@ server { set $skip_cache 1; } + # ...it's to the readiness endpoint + if ($request_uri = "/readiness") { + set $skip_cache 1; + } + # ...it's from a logged in user, the cookie 'wordpress_no_cache' exists. if ($http_cookie ~* "comment_author|wordpress_[a-f0-9]+|wp-postpass|wordpress_no_cache|wordpress_logged_in") { set $skip_cache 1; @@ -303,8 +308,18 @@ server { # LOCATIONS - heath ## - location ~ ^/(liveness|readiness)$ { + location = /liveness { return 200; } + location = /readiness { + # Make sure we can connect to php-fpm via the socket. + set $script_name /metrics/socket.php; + + fastcgi_param SCRIPT_FILENAME $document_root$script_name; + include fastcgi_params; + + fastcgi_pass fpm; + } + } diff --git a/public/metrics/service.php b/public/metrics/service.php index 8b81d26ef..c352d9bf3 100644 --- a/public/metrics/service.php +++ b/public/metrics/service.php @@ -140,6 +140,7 @@ public function serveMetrics(): void { header('Content-Type', 'text/plain'); echo $this->getServiceMetrics(); + unset($this->guzzle_client); exit(); } } diff --git a/public/metrics/socket.php b/public/metrics/socket.php new file mode 100644 index 000000000..1abc618f2 --- /dev/null +++ b/public/metrics/socket.php @@ -0,0 +1,3 @@ + Date: Wed, 30 Oct 2024 19:56:30 +0000 Subject: [PATCH 2/4] Update server.conf --- deploy/config/server.conf | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/deploy/config/server.conf b/deploy/config/server.conf index 67a6742d8..03f86f2ed 100644 --- a/deploy/config/server.conf +++ b/deploy/config/server.conf @@ -135,6 +135,11 @@ server { set $skip_cache 1; } + # ...it's to the readiness endpoint + if ($request_uri = "/readiness") { + set $skip_cache 1; + } + # ...it's from a logged in user, the cookie 'wordpress_no_cache' exists. if ($http_cookie ~* "comment_author|wordpress_[a-f0-9]+|wp-postpass|wordpress_no_cache|wordpress_logged_in") { set $skip_cache 1; @@ -325,7 +330,7 @@ server { # LOCATIONS - health ## - location ~ ^/(liveness|readiness)$ { + location = /liveness { if ($ip_access_health = 0) { return 404; } @@ -333,4 +338,18 @@ server { return 200; } + location = /readiness { + if ($ip_access_health = 0) { + return 404; + } + + # Make sure we can connect to php-fpm via the socket. + set $script_name /metrics/socket.php; + + fastcgi_param SCRIPT_FILENAME $document_root$script_name; + include fastcgi_params; + + fastcgi_pass fpm; + } + } From d129c17744f0a5f969627ee568183b36192479e6 Mon Sep 17 00:00:00 2001 From: EarthlingDavey <15802017+EarthlingDavey@users.noreply.github.com> Date: Thu, 31 Oct 2024 08:33:05 +0000 Subject: [PATCH 3/4] Add caching and skip service on production. --- deploy/config/server.conf | 4 ++-- public/metrics/service.php | 5 +++++ 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/deploy/config/server.conf b/deploy/config/server.conf index 03f86f2ed..0a50c7140 100644 --- a/deploy/config/server.conf +++ b/deploy/config/server.conf @@ -135,8 +135,8 @@ server { set $skip_cache 1; } - # ...it's to the readiness endpoint - if ($request_uri = "/readiness") { + # ...it's to the liveness or readiness endpoint + if ($request_uri ~* "^(/liveness|/readiness)$" { set $skip_cache 1; } diff --git a/public/metrics/service.php b/public/metrics/service.php index c352d9bf3..8bca24b43 100644 --- a/public/metrics/service.php +++ b/public/metrics/service.php @@ -35,6 +35,11 @@ class Metrics public function __construct() { + // Skip on production. + if ('production' === env('WP_ENV')) { + return; + } + // Get the ip group of the incoming request. $ip_group = $_SERVER['HTTP_X_MOJ_IP_GROUP'] ?? 0; From 46c06b31ed52536c37af50925b4d2513f2bc0bae Mon Sep 17 00:00:00 2001 From: EarthlingDavey <15802017+EarthlingDavey@users.noreply.github.com> Date: Thu, 31 Oct 2024 08:54:01 +0000 Subject: [PATCH 4/4] Update service.php --- public/metrics/service.php | 56 +++++++++++++++++++------------------- 1 file changed, 28 insertions(+), 28 deletions(-) diff --git a/public/metrics/service.php b/public/metrics/service.php index 8bca24b43..9cd98f512 100644 --- a/public/metrics/service.php +++ b/public/metrics/service.php @@ -34,12 +34,6 @@ class Metrics */ public function __construct() { - - // Skip on production. - if ('production' === env('WP_ENV')) { - return; - } - // Get the ip group of the incoming request. $ip_group = $_SERVER['HTTP_X_MOJ_IP_GROUP'] ?? 0; @@ -54,29 +48,8 @@ public function __construct() $this->home_url = env('WP_HOME'); - // Define an array of metrics that we want to generate. + // Define an array of metrics that we want to generate for all environments. $this->metrics_properties = [ - 'http_status_code_control' => [ - 'help' => 'The http status code when accessing an open site.', - 'type' => 'gauge', - 'callback' => [$this, 'getStatusCode'], - 'args' => [$this::OPEN_URL] - ], - 'http_status_code_invalid_header' => [ - 'help' => 'The http status code of when sending X-Moj-Ip-Group header.', - 'type' => 'gauge', - 'callback' => [$this, 'getStatusCode'], - 'args' => [ - $this->home_url, - ['headers' => ['X-Moj-Ip-Group' => 0]] - ] - ], - 'http_status_code_health' => [ - 'help' => 'The http status code of /health.', - 'type' => 'gauge', - 'callback' => [$this, 'getStatusCode'], - 'args' => ["{$this->home_url}/health"] - ], 'http_status_code_wp_home' => [ 'help' => 'The http status code when accessing this service via it\'s full url as defined in WP_HOME.', 'type' => 'gauge', @@ -84,6 +57,33 @@ public function __construct() 'args' => [$this->home_url] ] ]; + + if ('production' !== env('WP_ENV')) { + // Add other metrics for non-production. + $this->metrics_properties = array_merge($this->metrics_properties, [ + 'http_status_code_control' => [ + 'help' => 'The http status code when accessing an open site.', + 'type' => 'gauge', + 'callback' => [$this, 'getStatusCode'], + 'args' => [$this::OPEN_URL] + ], + 'http_status_code_invalid_header' => [ + 'help' => 'The http status code of when sending X-Moj-Ip-Group header.', + 'type' => 'gauge', + 'callback' => [$this, 'getStatusCode'], + 'args' => [ + $this->home_url, + ['headers' => ['X-Moj-Ip-Group' => 0]] + ] + ], + 'http_status_code_health' => [ + 'help' => 'The http status code of /health.', + 'type' => 'gauge', + 'callback' => [$this, 'getStatusCode'], + 'args' => ["{$this->home_url}/health"] + ] + ]); + } } /**