from typing import Any, Optional
from mlflow.gateway.client import MlflowGatewayClient
from mlflow.gateway.config import LimitsConfig, Route
from mlflow.gateway.constants import MLFLOW_GATEWAY_SEARCH_ROUTES_PAGE_SIZE
from mlflow.gateway.utils import gateway_deprecated
from mlflow.utils import get_results_from_paginated_fn
[docs]@gateway_deprecated
def get_route(name: str) -> Route:
"""
Retrieves a specific route from the MLflow Gateway service.
This function creates an instance of MlflowGatewayClient and uses it to fetch a route by its
name from the Gateway service.
Args:
name: The name of the route to fetch.
Returns:
An instance of the Route class representing the fetched route.
"""
return MlflowGatewayClient().get_route(name)
[docs]@gateway_deprecated
def search_routes() -> list[Route]:
"""
Searches for routes in the MLflow Gateway service.
This function creates an instance of MlflowGatewayClient and uses it to fetch a list of routes
from the Gateway service.
Returns:
A list of Route instances.
"""
def pagination_wrapper_func(_, next_page_token):
return MlflowGatewayClient().search_routes(page_token=next_page_token)
return get_results_from_paginated_fn(
paginated_fn=pagination_wrapper_func,
max_results_per_page=MLFLOW_GATEWAY_SEARCH_ROUTES_PAGE_SIZE,
max_results=None,
)
[docs]@gateway_deprecated
def create_route(
name: str, route_type: Optional[str] = None, model: Optional[dict[str, Any]] = None
) -> Route:
"""
Create a new route in the Gateway.
.. warning::
This API is ``only available`` when running within Databricks. When running elsewhere,
route configuration is handled via updates to the route configuration YAML file that
is specified during Gateway server start.
Args:
name: The name of the route. This parameter is required for all routes.
route_type: The type of the route (e.g., 'llm/v1/chat', 'llm/v1/completions',
'llm/v1/embeddings'). This parameter is required for routes that are
not managed by Databricks (the provider isn't 'databricks').
model: A dictionary representing the model details to be associated with the route.
This parameter is required for all routes. This dictionary should define:
- The model name (e.g., "gpt-4o-mini")
- The provider (e.g., "openai", "anthropic")
- The configuration for the model used in the route
Returns:
A serialized representation of the `Route` data structure,
providing information about the name, type, and model details for the
newly created route endpoint.
.. note::
See the official Databricks documentation for MLflow Gateway for examples of supported
model configurations and how to dynamically create new routes within Databricks.
Example usage from within Databricks:
.. code-block:: python
from mlflow.gateway import set_gateway_uri, create_route
set_gateway_uri(gateway_uri="databricks")
openai_api_key = ...
create_route(
name="my-route",
route_type="llm/v1/completions",
model={
"name": "question-answering-bot",
"provider": "openai",
"openai_config": {
"openai_api_key": openai_api_key,
},
},
)
"""
return MlflowGatewayClient().create_route(name, route_type, model)
[docs]@gateway_deprecated
def delete_route(name: str) -> None:
"""
Delete an existing route in the Gateway.
.. warning::
This API is **only available** when running within Databricks. When running elsewhere,
route deletion is handled by removing the corresponding entry from the route
configuration YAML file that is specified during Gateway server start.
Args:
name: The name of the route to delete.
Example usage from within Databricks:
.. code-block:: python
from mlflow.gateway import set_gateway_uri, delete_route
set_gateway_uri(gateway_uri="databricks")
delete_route("my-new-route")
"""
MlflowGatewayClient().delete_route(name)
[docs]@gateway_deprecated
def set_limits(route: str, limits: list[dict[str, Any]]) -> LimitsConfig:
"""
Set limits on an existing route in the Gateway.
.. warning::
This API is **only available** when running within Databricks.
Args:
route: The name of the route to set limits on.
limits: Limits to set on the route.
Example usage from within Databricks:
.. code-block:: python
from mlflow.gateway import set_gateway_uri, set_limits
set_gateway_uri(gateway_uri="databricks")
set_limits("my-new-route", [{"key": "user", "renewal_period": "minute", "calls": 50}])
"""
return MlflowGatewayClient().set_limits(route=route, limits=limits)
[docs]@gateway_deprecated
def get_limits(route: str) -> LimitsConfig:
"""
Get limits of an existing route in the Gateway.
.. warning::
This API is **only available** when connected to a Databricks-hosted AI Gateway.
Args:
route: The name of the route to get limits of.
Example usage from within Databricks:
.. code-block:: python
from mlflow.gateway import set_gateway_uri, get_limits
set_gateway_uri(gateway_uri="databricks")
get_limits("my-new-route")
"""
return MlflowGatewayClient().get_limits(route=route)
[docs]@gateway_deprecated
def query(route: str, data):
"""
Issues a query request to a configured service through a named route on the Gateway Server.
This function will interface with a configured route name (examples below) and return the
response from the provider in a standardized format.
Args:
route: The name of the configured route. Route names can be obtained by running
`mlflow.gateway.search_routes()`
data: The request payload to be submitted to the route. The exact configuration of
the expected structure varies based on the route configuration.
Returns:
The response from the configured route endpoint provider in a standardized format.
Chat example:
.. code-block:: python
from mlflow.gateway import query, set_gateway_uri
set_gateway_uri(gateway_uri="http://my.gateway:9000")
response = query(
"my_chat_route",
{"messages": [{"role": "user", "content": "What is the best day of the week?"}]},
)
Completions example:
.. code-block:: python
from mlflow.gateway import query, set_gateway_uri
set_gateway_uri(gateway_uri="http://my.gateway:9000")
response = query("a_completions_route", {"prompt": "Where do we go from"})
Embeddings example:
.. code-block:: python
from mlflow.gateway import query, set_gateway_uri
set_gateway_uri(gateway_uri="http://my.gateway:9000")
response = query(
"embeddings_route", {"text": ["I like spaghetti", "and sushi", "but not together"]}
)
Additional parameters that are valid for a given provider and route configuration can be
included with the request as shown below, using an openai completions route request as
an example:
.. code-block:: python
from mlflow.gateway import query, set_gateway_uri
set_gateway_uri(gateway_uri="http://my.gateway:9000")
response = query(
"a_completions_route",
{
"prompt": "Give me an example of a properly formatted pytest unit test",
"temperature": 0.6,
"max_tokens": 1000,
},
)
"""
return MlflowGatewayClient().query(route, data)