From: Tatjana Dehler Date: Thu, 7 Jul 2022 15:21:14 +0000 (+0200) Subject: mgr/dashboard: prevent alert redirect X-Git-Tag: v18.0.0~498^2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=refs%2Fpull%2F47011%2Fhead;p=ceph.git mgr/dashboard: prevent alert redirect Prevent Alertmanager alerts from being redirected to the active mgr dashboard instance. There are two reasons for it: 1. It doesn't bring any additional benefit. The Alertmanager config includes all available mgr instances - active and passive ones. In case of an alert, it will be sent to all of them. It ensures that the active mgr dashboard will receive the alert in any case. 2. The redirect URL includes the mgr IP and NOT the FQDN. This leads to issues in environments where an SSL certificate is configured and matches the FQDNs, only. Fixes: https://tracker.ceph.com/issues/56401 Signed-off-by: Tatjana Dehler --- diff --git a/src/pybind/mgr/dashboard/module.py b/src/pybind/mgr/dashboard/module.py index 5b2f90ab204d..946c853f880d 100644 --- a/src/pybind/mgr/dashboard/module.py +++ b/src/pybind/mgr/dashboard/module.py @@ -517,6 +517,13 @@ class StandbyModule(MgrStandbyModule, CherryPyConfig): def default(self, *args, **kwargs): if module.get_module_option('standby_behaviour', 'redirect') == 'redirect': active_uri = module.get_active_uri() + + if cherrypy.request.path_info.startswith('/api/prometheus_receiver'): + module.log.debug("Suppressed redirecting alert to active '%s'", + active_uri) + cherrypy.response.status = 204 + return None + if active_uri: module.log.info("Redirecting to active '%s'", active_uri) raise cherrypy.HTTPRedirect(active_uri)