Mysql
 sql >> Database >  >> RDS >> Mysql

Flask-SQLAlchemy controlla se il server di database è reattivo

C'è una libreria di fantasia per scrivere la condizione di controllo dell'end-point del servizio - healthcheck .

Puoi usarlo invece di creare manualmente l'end-point perché ci sono alcune funzionalità pronte all'uso (ad esempio EnvironmentDump ).

Nella mia applicazione, avevo la stessa esigenza, quindi ho implementato il controllo se il database è reattivo

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)

Come vedo, nella tua applicazione puoi eseguire query con db.engine.execute('SELECT 1') .