From 69ddf764b6b492eceab67a9e4a8128afe18b8dd0 Mon Sep 17 00:00:00 2001 From: Alex Norell Date: Mon, 30 Dec 2024 09:22:41 -0800 Subject: [PATCH] Add readiness endpoint for dedicated deployments --- inference/core/interfaces/http/http_api.py | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/inference/core/interfaces/http/http_api.py b/inference/core/interfaces/http/http_api.py index 26c8459d1..95eac9057 100644 --- a/inference/core/interfaces/http/http_api.py +++ b/inference/core/interfaces/http/http_api.py @@ -1458,7 +1458,11 @@ async def consume( ) # Enable preloading models at startup - if PRELOAD_MODELS and API_KEY and not LAMBDA: + if ( + (PRELOAD_MODELS or DEDICATED_DEPLOYMENT_WORKSPACE_URL) + and API_KEY + and not LAMBDA + ): class ModelInitState: """Class to track model initialization state.""" @@ -1501,11 +1505,12 @@ async def load_model(model_id): async with state.lock: state.initialization_errors.append((model_id, str(e))) - # Create tasks for each model to be loaded - tasks = [load_model(model_id) for model_id in PRELOAD_MODELS] + if PRELOAD_MODELS: + # Create tasks for each model to be loaded + tasks = [load_model(model_id) for model_id in PRELOAD_MODELS] - # Wait for all tasks to complete, collecting exceptions - await asyncio.gather(*tasks, return_exceptions=True) + # Wait for all tasks to complete, collecting exceptions + await asyncio.gather(*tasks, return_exceptions=True) # Update the readiness state in a thread-safe manner async with state.lock: