Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,25 @@

import httpx
from fastapi import FastAPI
from servicelib.fastapi.tracing import setup_httpx_client_tracing
from settings_library.tracing import TracingSettings


def setup_client_session(
app: FastAPI,
*,
default_timeout: datetime.timedelta = datetime.timedelta(seconds=20),
max_keepalive_connections: int = 20
max_keepalive_connections: int = 20,
tracing_settings: TracingSettings | None,
) -> None:
async def on_startup() -> None:
session = httpx.AsyncClient(
transport=httpx.AsyncHTTPTransport(http2=True),
limits=httpx.Limits(max_keepalive_connections=max_keepalive_connections),
timeout=default_timeout.total_seconds(),
)
if tracing_settings:
setup_httpx_client_tracing(session)
app.state.aiohttp_client_session = session

async def on_shutdown() -> None:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ def create_app(settings: ApplicationSettings) -> FastAPI:
app,
max_keepalive_connections=settings.DIRECTOR_REGISTRY_CLIENT_MAX_KEEPALIVE_CONNECTIONS,
default_timeout=settings.DIRECTOR_REGISTRY_CLIENT_TIMEOUT,
tracing_settings=settings.DIRECTOR_TRACING,
)
setup_registry(app)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ def create_app(settings: ApplicationSettings) -> FastAPI: # noqa: C901

setup_db(app)
setup_s3(app)
setup_client_session(app)
setup_client_session(app, tracing_settings=settings.STORAGE_TRACING)

if settings.STORAGE_CELERY and not settings.STORAGE_WORKER_MODE:
setup_rabbitmq(app)
Expand Down
Loading