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')
.