Source code for monasca_api.healthcheck.alarms_db_check
# Copyright 2017 FUJITSU LIMITED
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from oslo_log import log
from sqlalchemy import text
from monasca_api.common.repositories.sqla import sql_repository
from monasca_api.healthcheck import base
LOG = log.getLogger(__name__)
[docs]class AlarmsDbHealthCheck(base.BaseHealthCheck,
sql_repository.SQLRepository):
"""Evaluates alarm db health
Healthcheck verifies if:
* database is up and running, it is possible to establish connection
* sample sql query can be executed
If following conditions are met health check return healthy status.
Otherwise unhealthy status is returned with explanation.
"""
[docs] def health_check(self):
status = self.check_db_status()
return base.CheckResult(healthy=status[0],
message=status[1])
[docs] def check_db_status(self):
try:
with self._db_engine.connect() as con:
query = text('SELECT 1')
con.execute(query)
except Exception as ex:
LOG.exception(str(ex))
return False, str(ex)
return True, 'OK'