Skip to content

kubernetes-sigs/gateway-api-inference-extension

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Go Report Card Go Reference License

Gateway API Inference Extension

Gateway API Inference Extension optimizes self-hosting Generative Models on Kubernetes. This is achieved by leveraging Envoy's External Processing (ext-proc) to extend any gateway that supports both ext-proc and Gateway API into an inference gateway.

Concepts and Definitions

The following specific terms to this project:

  • Inference Gateway (IGW): A proxy/load-balancer which has been coupled with an Endpoint Picker. It provides optimized routing and load balancing for serving Kubernetes self-hosted generative Artificial Intelligence (AI) workloads. It simplifies the deployment, management, and observability of AI inference workloads.
  • Inference Scheduler: An extendable component that makes decisions about which endpoint is optimal (best cost / best performance) for an inference request based on Metrics and Capabilities from Model Serving.
  • Metrics and Capabilities: Data provided by model serving platforms about performance, availability and capabilities to optimize routing. Includes things like Prefix Cache status or LoRA Adapters availability.
  • Endpoint Picker(EPP): An implementation of an Inference Scheduler with additional Routing, Flow, and Request Control layers to allow for sophisticated routing strategies. Additional info on the architecture of the EPP here.

The following are key industry terms that are important to understand for this project:

  • Model: A generative AI model that has learned patterns from data and is used for inference. Models vary in size and architecture, from smaller domain-specific models to massive multi-billion parameter neural networks that are optimized for diverse language tasks.
  • Inference: The process of running a generative AI model, such as a large language model, diffusion model etc, to generate text, embeddings, or other outputs from input data.
  • Model server: A service (in our case, containerized) responsible for receiving inference requests and returning predictions from a model.
  • Accelerator: specialized hardware, such as Graphics Processing Units (GPUs) that can be attached to Kubernetes nodes to speed up computations, particularly for training and inference tasks.

For deeper insights and more advanced concepts, refer to our proposals.

Technical Overview

This extension upgrades an ext-proc capable proxy or gateway - such as Envoy Gateway, kGateway, or the GKE Gateway - to become an inference gateway - supporting inference platform teams self-hosting Generative Models (with a current focus on large language models) on Kubernetes. This integration makes it easy to expose and control access to your local OpenAI-compatible chat completion endpoints to other workloads on or off cluster, or to integrate your self-hosted models alongside model-as-a-service providers in a higher level AI Gateway like LiteLLM, Solo AI Gateway, or Apigee.

The Inference Gateway:

  • Improves the tail latency and throughput of LLM completion requests against Kubernetes-hosted model servers using an extensible request scheduling alogrithm that is kv-cache and request cost aware, avoiding evictions or queueing as load increases
  • Provides Kubernetes-native declarative APIs to route client model names to use-case specific LoRA adapters and control incremental rollout of new adapter versions, A/B traffic splitting, and safe blue-green base model and model server upgrades
  • Adds end to end observability around service objective attainment
  • Ensures operational guardrails between different client model names, allowing a platform team to safely serve many different GenAI workloads on the same pool of shared foundation model servers for higher utilization and fewer required accelerators

Architecture Diagram

It currently requires a version of vLLM that supports the necessary metrics to predict traffic load which is defined in the model server protocol. Support for Google's Jetstream, nVidia Triton, text-generation-inference, and SGLang is coming soon.

Status

This project is alpha (0.3 release). It should not be used in production yet.

Getting Started

Follow our Getting Started Guide to get the inference-extension up and running on your cluster!

See our website at https://gateway-api-inference-extension.sigs.k8s.io/ for detailed API documentation on leveraging our Kubernetes-native declarative APIs

Roadmap

As Inference Gateway builds towards a GA release. We will continue to expand our capabilities, namely:

  1. Prefix-cache aware load balancing with interfaces for remote caches
  2. Recommended LoRA adapter pipeline for automated rollout
  3. Fairness and priority between workloads within the same criticality band
  4. HPA support for autoscaling on aggregate metrics derived from the load balancer
  5. Support for large multi-modal inputs and outputs
  6. Support for other GenAI model types (diffusion and other non-completion protocols)
  7. Heterogeneous accelerators - serve workloads on multiple types of accelerator using latency and request cost-aware load balancing
  8. Disaggregated serving support with independently scaling pools

End-to-End Tests

Follow this README to learn more about running the inference-extension end-to-end test suite on your cluster.

Contributing

Our community meeting is weekly at Thursday 10AM PDT (Zoom, Meeting Notes).

We currently utilize the #wg-serving slack channel for communications.

Contributions are readily welcomed, follow the dev guide to start contributing!

Code of conduct

Participation in the Kubernetes community is governed by the Kubernetes Code of Conduct.