|
| 1 | +import asyncio |
| 2 | +import logging |
| 3 | +from collections.abc import AsyncGenerator |
| 4 | +from contextlib import asynccontextmanager |
| 5 | + |
| 6 | +import prometheus_client |
1 | 7 | from fastapi import FastAPI |
2 | 8 | from fastapi.middleware.cors import CORSMiddleware |
3 | 9 | from fastapi.middleware.trustedhost import TrustedHostMiddleware |
4 | 10 |
|
5 | 11 | from app.auth.views import router as auth_router |
| 12 | +from app.core import database_session, metrics |
6 | 13 | from app.core.config import get_settings |
7 | 14 |
|
| 15 | +logger = logging.getLogger(__name__) |
| 16 | + |
| 17 | + |
| 18 | +@asynccontextmanager |
| 19 | +async def lifespan(_: FastAPI) -> AsyncGenerator[None]: |
| 20 | + logger.info("starting application...") |
| 21 | + if get_settings().prometheus.enabled: |
| 22 | + logger.info( |
| 23 | + "starting prometheus client server on interface %s port %d", |
| 24 | + get_settings().prometheus.addr, |
| 25 | + get_settings().prometheus.port, |
| 26 | + ) |
| 27 | + |
| 28 | + prometheus_client.start_http_server( |
| 29 | + addr=get_settings().prometheus.addr, |
| 30 | + port=get_settings().prometheus.port, |
| 31 | + ) |
| 32 | + metrics.APP_STARTED.inc() |
| 33 | + |
| 34 | + yield |
| 35 | + |
| 36 | + logger.info("shutting down application...") |
| 37 | + |
| 38 | + await database_session._ASYNC_ENGINE.dispose() |
| 39 | + logger.info("disposed database engine and closed connections...") |
| 40 | + |
| 41 | + if get_settings().prometheus.enabled: |
| 42 | + logger.info( |
| 43 | + "stopping prometheus with delay of %d seconds...", |
| 44 | + get_settings().prometheus.stop_delay_secs, |
| 45 | + ) |
| 46 | + metrics.APP_STOPPED.inc() |
| 47 | + await asyncio.sleep(get_settings().prometheus.stop_delay_secs) |
| 48 | + |
| 49 | + logger.info("bye! application shutdown completed") |
| 50 | + |
| 51 | + |
8 | 52 | app = FastAPI( |
9 | 53 | title="minimal fastapi postgres template", |
10 | 54 | version="7.0.0", |
11 | 55 | description="https://github.com/rafsaf/minimal-fastapi-postgres-template", |
12 | 56 | openapi_url="/openapi.json", |
13 | 57 | docs_url="/", |
| 58 | + lifespan=lifespan, |
14 | 59 | ) |
15 | 60 |
|
16 | 61 | app.include_router(auth_router, prefix="/auth", tags=["auth"]) |
|
0 commit comments