Provide new parameter to disable health check

Provide a new parameter in cluster API initilalize func to disable
health check and endpoint accessiblitlity check.
By default the value is True, for some scenarios, when creating
a nsxlib object, users does not intend to validate the endpoint
state, for example, in ncp election process.

Change-Id: I6485a91f1d764fbb7ae3edc61541b7cd9f97682e
This commit is contained in:
sean 2021-02-25 18:29:29 -08:00
parent 10366f00ba
commit ce1d1e2424
4 changed files with 58 additions and 29 deletions

View File

@ -396,7 +396,8 @@ class NsxClientTestCase(NsxLibTestCase):
return client return client
def new_mocked_cluster(self, conf_managers, validate_conn_func, def new_mocked_cluster(self, conf_managers, validate_conn_func,
concurrent_connections=None, exceptions=None): concurrent_connections=None, exceptions=None,
enable_health_check=True):
mock_provider = mock.Mock() mock_provider = mock.Mock()
mock_provider.default_scheme = 'https' mock_provider.default_scheme = 'https'
mock_provider.validate_connection = validate_conn_func mock_provider.validate_connection = validate_conn_func
@ -406,6 +407,7 @@ class NsxClientTestCase(NsxLibTestCase):
nsxlib_config.exception_config = exceptions nsxlib_config.exception_config = exceptions
if concurrent_connections: if concurrent_connections:
nsxlib_config.concurrent_connections = concurrent_connections nsxlib_config.concurrent_connections = concurrent_connections
nsxlib_config.enable_health_check = enable_health_check
nsxlib_config.http_provider = mock_provider nsxlib_config.http_provider = mock_provider
nsxlib_config.nsx_api_managers = conf_managers nsxlib_config.nsx_api_managers = conf_managers

View File

@ -553,3 +553,11 @@ class ClusteredAPITestCase(nsxlib_testcase.NsxClientTestCase):
api = self.mock_nsx_clustered_api() api = self.mock_nsx_clustered_api()
# just make sure this api is defined, and does not crash # just make sure this api is defined, and does not crash
api._reinit_cluster() api._reinit_cluster()
def test_initialize_cluster_without_health_check(self):
conf_managers = ['8.9.10.11', '9.10.11.12']
validate_fn = mock.MagicMock()
api = self.new_mocked_cluster(conf_managers, validate_fn,
enable_health_check=False)
self.assertEqual(cluster.ClusterHealth.GREEN, api.health)
validate_fn.assert_not_called()

View File

@ -451,18 +451,21 @@ class ClusteredAPI(object):
keepalive_interval=33, keepalive_interval=33,
api_rate_limit=None, api_rate_limit=None,
api_rate_mode=None, api_rate_mode=None,
api_log_mode=None): api_log_mode=None,
enable_health_check=True):
self._http_provider = http_provider self._http_provider = http_provider
self._keepalive_interval = keepalive_interval self._keepalive_interval = keepalive_interval
self._print_keepalive = 0 self._print_keepalive = 0
self._silent = False self._silent = False
self._api_call_collectors = [] self._api_call_collectors = []
self._enable_health_check = enable_health_check
def _init_cluster(*args, **kwargs): def _init_cluster(*args, **kwargs):
self._init_endpoints(providers, min_conns_per_pool, self._init_endpoints(providers, min_conns_per_pool,
max_conns_per_pool, api_rate_limit, max_conns_per_pool, api_rate_limit,
api_rate_mode, api_log_mode) api_rate_mode, api_log_mode,
enable_health_check)
_init_cluster() _init_cluster()
@ -476,7 +479,7 @@ class ClusteredAPI(object):
def _init_endpoints(self, providers, min_conns_per_pool, def _init_endpoints(self, providers, min_conns_per_pool,
max_conns_per_pool, api_rate_limit, api_rate_mode, max_conns_per_pool, api_rate_limit, api_rate_mode,
api_log_mode): api_log_mode, enable_health_check=True):
LOG.debug("Initializing API endpoints") LOG.debug("Initializing API endpoints")
def _create_conn(p): def _create_conn(p):
@ -516,7 +519,9 @@ class ClusteredAPI(object):
# duck type to proxy http invocations # duck type to proxy http invocations
for method in ClusteredAPI._HTTP_VERBS: for method in ClusteredAPI._HTTP_VERBS:
setattr(self, method, self._proxy_stub(method)) setattr(self, method, self._proxy_stub(method))
# If health check is disabled, skip endpoint accessiblity check
# and health check loop. Set api health to GREEN.
if enable_health_check:
conns = greenpool.GreenPool() conns = greenpool.GreenPool()
for endpoint in self._endpoints.values(): for endpoint in self._endpoints.values():
conns.spawn(self._validate, endpoint) conns.spawn(self._validate, endpoint)
@ -540,6 +545,9 @@ class ClusteredAPI(object):
loop.start(initial_delay=self._keepalive_interval, loop.start(initial_delay=self._keepalive_interval,
periodic_interval_max=self._keepalive_interval, periodic_interval_max=self._keepalive_interval,
stop_on_exception=False) stop_on_exception=False)
else:
for endpoint in self._endpoints.values():
endpoint.set_state(EndpointState.UP)
LOG.debug("Done initializing API endpoint(s). " LOG.debug("Done initializing API endpoint(s). "
"API cluster health: %s", self.health) "API cluster health: %s", self.health)
@ -831,7 +839,8 @@ class NSXClusteredAPI(ClusteredAPI):
keepalive_interval=self.nsxlib_config.conn_idle_timeout, keepalive_interval=self.nsxlib_config.conn_idle_timeout,
api_rate_limit=self.nsxlib_config.api_rate_limit_per_endpoint, api_rate_limit=self.nsxlib_config.api_rate_limit_per_endpoint,
api_rate_mode=self.nsxlib_config.api_rate_mode, api_rate_mode=self.nsxlib_config.api_rate_mode,
api_log_mode=self.nsxlib_config.api_log_mode) api_log_mode=self.nsxlib_config.api_log_mode,
enable_health_check=self.nsxlib_config.enable_health_check)
LOG.debug("Created NSX clustered API with '%s' " LOG.debug("Created NSX clustered API with '%s' "
"provider", self._http_provider.provider_id) "provider", self._http_provider.provider_id)

View File

@ -158,6 +158,14 @@ class NsxLibConfig(object):
When set to API_LOG_PER_ENDPOINT, API calls sent to When set to API_LOG_PER_ENDPOINT, API calls sent to
each endpoint will be collected individually. each endpoint will be collected individually.
By default, this option is disabled as set to None. By default, this option is disabled as set to None.
:param enable_health_check: Options to enable or disable health check for
all endpoints when initializing cluster API.
The checking including endpoint connection
validation and health check loop.
For some condition, eg election process. It
does not need to check the endpoint's
accessibility.
By default, this option is set to True.
-- Additional parameters which are relevant only for the Policy manager: -- Additional parameters which are relevant only for the Policy manager:
:param allow_passthrough: If True, use nsx manager api for cases which are :param allow_passthrough: If True, use nsx manager api for cases which are
@ -198,7 +206,8 @@ class NsxLibConfig(object):
api_rate_limit_per_endpoint=None, api_rate_limit_per_endpoint=None,
api_rate_mode=None, api_rate_mode=None,
exception_config=None, exception_config=None,
api_log_mode=None): api_log_mode=None,
enable_health_check=True):
self.nsx_api_managers = nsx_api_managers self.nsx_api_managers = nsx_api_managers
self._username = username self._username = username
@ -230,6 +239,7 @@ class NsxLibConfig(object):
self.api_rate_mode = api_rate_mode self.api_rate_mode = api_rate_mode
self.exception_config = exception_config or ExceptionConfig() self.exception_config = exception_config or ExceptionConfig()
self.api_log_mode = api_log_mode self.api_log_mode = api_log_mode
self.enable_health_check = enable_health_check
if len(nsx_api_managers) == 1 and not self.cluster_unavailable_retry: if len(nsx_api_managers) == 1 and not self.cluster_unavailable_retry:
LOG.warning("When only one endpoint is provided, keepalive probes" LOG.warning("When only one endpoint is provided, keepalive probes"