Mysql
 sql >> Base de données >  >> RDS >> Mysql

Flask-SQLAlchemy vérifie si le serveur de base de données est réactif

Il existe une bibliothèque sophistiquée pour écrire la condition de vérification du point final du service - healthcheck .

Vous pouvez l'utiliser au lieu de créer manuellement un point de terminaison car certaines fonctionnalités sont prêtes à l'emploi (par exemple EnvironmentDump ).

Dans mon application, j'avais le même besoin, j'ai donc implémenté vérifier si la base de données est réactive

app = Flask(__name__)

# wrap the flask app and give a heathcheck url
health = HealthCheck(app, "/healthcheck")

def health_database_status():
    is_database_working = True
    output = 'database is ok'

    try:
        # to check database we will execute raw query
        session = DatabaseSession.get_database_session()
        session.execute('SELECT 1')
    except Exception as e:
        output = str(e)
        is_database_working = False

    return is_database_working, output

health.add_check(health_database_status)

Comme je le vois, dans votre application, vous pouvez exécuter une requête avec db.engine.execute('SELECT 1') .