monasca-api/monasca_api/healthcheck/alarms_db_check.py
Artur Basiak 4e168edf6e Add healtcheck endpoint
Provide new healtcheck endpoint to monasca-api.
Add simple check for HEAD and complex check for GET.
Complex check contains information about dependent
services like:
- kafka
- relational database (mariadb, postgresql)
- timeseries database (influxdb, cassandra)

Story: 2000974
Task: 4125

Change-Id: I863071194041a512b144262bbffce5024b97086b
2017-05-30 11:30:56 +02:00

50 lines
1.6 KiB
Python

# 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__)
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.
"""
def health_check(self):
status = self.check_db_status()
return base.CheckResult(healthy=status[0],
message=status[1])
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'