diff options
author | Davis Haupt <davis.haupt@mongodb.com> | 2022-01-11 16:26:37 +0000 |
---|---|---|
committer | Evergreen Agent <no-reply@evergreen.mongodb.com> | 2022-01-11 17:12:56 +0000 |
commit | 954c679f963b0e8e39010c748b53bd80e1109467 (patch) | |
tree | ac5ded961f4feeb70438f92ce97565cc61103ad3 /src/mongo/db/process_health | |
parent | 89bc7e2241fd1e2fcd34f7226a5d5f50b543d33f (diff) | |
download | mongo-954c679f963b0e8e39010c748b53bd80e1109467.tar.gz |
SERVER-59391 fault if LDAP facets are enabled but misconfigured
Diffstat (limited to 'src/mongo/db/process_health')
5 files changed, 31 insertions, 0 deletions
diff --git a/src/mongo/db/process_health/fault_manager.cpp b/src/mongo/db/process_health/fault_manager.cpp index 1e57fadd1ce..830e7e2834c 100644 --- a/src/mongo/db/process_health/fault_manager.cpp +++ b/src/mongo/db/process_health/fault_manager.cpp @@ -349,6 +349,7 @@ boost::optional<FaultState> FaultManager::handleTransientFault(const OptionalMes } boost::optional<FaultState> FaultManager::handleActiveFault(const OptionalMessageType& message) { + invariant(_fault); LOGV2_FATAL(5936509, "Halting Process due to ongoing fault", "fault"_attr = *_fault); return boost::none; } @@ -418,6 +419,15 @@ void FaultManager::schedulePeriodicHealthCheckThread() { listOfActiveObservers << observer->getType() << " "; auto token = _managerShuttingDownCancellationSource.token(); + if (!observer->isConfigured()) { + // Transition to an active fault if a health observer is not configured properly. + updateWithCheckStatus(HealthCheckStatus( + observer->getType(), + Severity::kFailure, + "Health observer failed to start because it was not configured properly."_sd)); + setState(FaultState::kActiveFault, HealthCheckStatus(observer->getType())); + return; + } healthCheck(observer, token); } LOGV2(5936804, "Health observers started", "detail"_attr = listOfActiveObservers); diff --git a/src/mongo/db/process_health/health_observer.h b/src/mongo/db/process_health/health_observer.h index cdfeeb81f08..a5a48306929 100644 --- a/src/mongo/db/process_health/health_observer.h +++ b/src/mongo/db/process_health/health_observer.h @@ -89,6 +89,13 @@ public: * Timeout value enforced on an individual health check. */ virtual Milliseconds getObserverTimeout() const = 0; + + /** + * Returns false if the health observer is missing some configuration it needs for its health + * checks. In the case of faulty configuration, make sure to log any helpful messages within + * this method. + */ + virtual bool isConfigured() const = 0; }; } // namespace process_health diff --git a/src/mongo/db/process_health/health_observer_mock.h b/src/mongo/db/process_health/health_observer_mock.h index 5ab2e65d7f1..644cfa3c247 100644 --- a/src/mongo/db/process_health/health_observer_mock.h +++ b/src/mongo/db/process_health/health_observer_mock.h @@ -53,6 +53,10 @@ public: virtual ~HealthObserverMock() = default; + bool isConfigured() const override { + return true; + } + protected: FaultFacetType getType() const override { return _mockType; diff --git a/src/mongo/db/process_health/test_health_observer.cpp b/src/mongo/db/process_health/test_health_observer.cpp index 6ab40e5e799..41b2087372c 100644 --- a/src/mongo/db/process_health/test_health_observer.cpp +++ b/src/mongo/db/process_health/test_health_observer.cpp @@ -38,6 +38,7 @@ namespace mongo { namespace process_health { MONGO_FAIL_POINT_DEFINE(hangTestHealthObserver); MONGO_FAIL_POINT_DEFINE(testHealthObserver); +MONGO_FAIL_POINT_DEFINE(badConfigTestHealthObserver); Future<HealthCheckStatus> TestHealthObserver::periodicCheckImpl( PeriodicHealthCheckContext&& periodicCheckContext) { LOGV2_DEBUG(5936801, 2, "Test health observer executing"); @@ -59,6 +60,13 @@ Future<HealthCheckStatus> TestHealthObserver::periodicCheckImpl( return result; } +bool TestHealthObserver::isConfigured() const { + if (badConfigTestHealthObserver.shouldFail()) { + return false; + } + return true; +} + namespace { MONGO_INITIALIZER(TestHealthObserver)(InitializerContext*) { // Failpoints can only be set when test commands are enabled, and so the test health observer diff --git a/src/mongo/db/process_health/test_health_observer.h b/src/mongo/db/process_health/test_health_observer.h index 85de8a65998..f325ac71534 100644 --- a/src/mongo/db/process_health/test_health_observer.h +++ b/src/mongo/db/process_health/test_health_observer.h @@ -51,6 +51,8 @@ protected: Future<HealthCheckStatus> periodicCheckImpl( PeriodicHealthCheckContext&& periodicCheckContext) override; + + bool isConfigured() const override; }; } // namespace process_health } // namespace mongo |