Getting started with an Inference Gateway¶
Experimental
This project is still in an alpha state and breaking changes may occur in the future.
Warning
This page is out of date with the v1.0.0 release candidate. Updates under active development
This quickstart guide is intended for engineers familiar with k8s and model servers (vLLM in this instance). The goal of this guide is to get an Inference Gateway up and running!
Prerequisites¶
A cluster with:
  - Support for services of type LoadBalancer. For kind clusters, follow this guide
  to get services of type LoadBalancer working.
  - Support for sidecar containers (enabled by default since Kubernetes v1.29)
  to run the model server deployment.
Tooling: - Helm installed
Steps¶
Deploy Sample Model Server¶
Three options are supported for running the model server:
- 
GPU-based model server. Requirements: a Hugging Face access token that grants access to the model meta-llama/Llama-3.1-8B-Instruct. 
- 
CPU-based model server (not using GPUs). The sample uses the model Qwen/Qwen2.5-1.5B-Instruct. 
- 
vLLM Simulator model server (not using GPUs). The sample is configured to simulate the meta-llama/Llama-3.1-8B-Instruct model. 
Choose one of these options and follow the steps below. Please do not deploy more than one, as the deployments have the same name and will override each other.
For this setup, you will need 3 GPUs to run the sample model server. Adjust the number of replicas in ./config/manifests/vllm/gpu-deployment.yaml as needed.
  Create a Hugging Face secret to download the model meta-llama/Llama-3.1-8B-Instruct. Ensure that the token grants access to this model.
Deploy a sample vLLM deployment with the proper protocol to work with the LLM Instance Gateway.
kubectl create secret generic hf-token --from-literal=token=$HF_TOKEN # Your Hugging Face Token with access to the set of Llama models
kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/vllm/gpu-deployment.yaml
This setup is using the formal vllm-cpu image, which according to the documentation can run vLLM on x86 CPU platform.
  For this setup, we use approximately 9.5GB of memory and 12 CPUs for each replica.
While it is possible to deploy the model server with less resources, this is not recommended. For example, in our tests, loading the model using 8GB of memory and 1 CPU was possible but took almost 3.5 minutes and inference requests took unreasonable time. In general, there is a tradeoff between the memory and CPU we allocate to our pods and the performance. The more memory and CPU we allocate the better performance we can get.
After running multiple configurations of these values we decided in this sample to use 9.5GB of memory and 12 CPUs for each replica, which gives reasonable response times. You can increase those numbers and potentially may even get better response times. For modifying the allocated resources, adjust the numbers in cpu-deployment.yaml as needed.
Deploy a sample vLLM deployment with the proper protocol to work with the LLM Instance Gateway.
kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/vllm/cpu-deployment.yaml
This option uses the vLLM simulator to simulate a backend model server. This setup uses the least amount of compute resources, does not require GPU's, and is ideal for test/dev environments.
To deploy the vLLM simulator, run the following command.
kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/vllm/sim-deployment.yaml
Install the Inference Extension CRDs¶
kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/releases/latest/download/manifests.yaml
Deploy the InferencePool and Endpoint Picker Extension¶
Install an InferencePool named vllm-llama3-8b-instruct that selects from endpoints with label app: vllm-llama3-8b-instruct and listening on port 8000. The Helm install command automatically installs the endpoint-picker, inferencepool along with provider specific resources.
Deploy the InferencePool and Endpoint Picker Extension¶
Install an InferencePool named vllm-llama3-8b-instruct that selects from endpoints with label app: vllm-llama3-8b-instruct and listening on port 8000. The Helm install command automatically installs the endpoint-picker, inferencepool along with provider specific resources.
export GATEWAY_PROVIDER=gke
helm install vllm-llama3-8b-instruct \
--set inferencePool.modelServers.matchLabels.app=vllm-llama3-8b-instruct \
--set provider.name=$GATEWAY_PROVIDER \
--version v0.5.1 \
oci://registry.k8s.io/gateway-api-inference-extension/charts/inferencepool
export GATEWAY_PROVIDER=none
helm install vllm-llama3-8b-instruct \
--set inferencePool.modelServers.matchLabels.app=vllm-llama3-8b-instruct \
--set provider.name=$GATEWAY_PROVIDER \
--version v0.5.1 \
oci://registry.k8s.io/gateway-api-inference-extension/charts/inferencepool
export GATEWAY_PROVIDER=none
helm install vllm-llama3-8b-instruct \
--set inferencePool.modelServers.matchLabels.app=vllm-llama3-8b-instruct \
--set provider.name=$GATEWAY_PROVIDER \
--version v0.5.1 \
oci://registry.k8s.io/gateway-api-inference-extension/charts/inferencepool
export GATEWAY_PROVIDER=none
helm install vllm-llama3-8b-instruct \
--set inferencePool.modelServers.matchLabels.app=vllm-llama3-8b-instruct \
--set provider.name=$GATEWAY_PROVIDER \
--version v0.5.1 \
oci://registry.k8s.io/gateway-api-inference-extension/charts/inferencepool
Deploy an Inference Gateway¶
Choose one of the following options to deploy an Inference Gateway.
- 
Enable the Google Kubernetes Engine API, Compute Engine API, the Network Services API and configure proxy-only subnets when necessary. See Deploy Inference Gateways for detailed instructions. 
- 
Deploy Inference Gateway: kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/gke/gateway.yamlConfirm that the Gateway was assigned an IP address and reports a Programmed=Truestatus:$ kubectl get gateway inference-gateway NAME CLASS ADDRESS PROGRAMMED AGE inference-gateway inference-gateway <MY_ADDRESS> True 22s
- 
Deploy the HTTPRoute kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/gke/httproute.yaml
- 
Confirm that the HTTPRoute status conditions include Accepted=TrueandResolvedRefs=True:kubectl get httproute llm-route -o yaml
Please note that this feature is currently in an experimental phase and is not intended for production use. The implementation and user experience are subject to changes as we continue to iterate on this project.
- 
Requirements - Gateway API CRDs installed.
 
- 
Install Istio TAG=$(curl https://storage.googleapis.com/istio-build/dev/1.27-dev) # on Linux wget https://storage.googleapis.com/istio-build/dev/$TAG/istioctl-$TAG-linux-amd64.tar.gz tar -xvf istioctl-$TAG-linux-amd64.tar.gz # on macOS wget https://storage.googleapis.com/istio-build/dev/$TAG/istioctl-$TAG-osx.tar.gz tar -xvf istioctl-$TAG-osx.tar.gz # on Windows wget https://storage.googleapis.com/istio-build/dev/$TAG/istioctl-$TAG-win.zip unzip istioctl-$TAG-win.zip ./istioctl install --set tag=$TAG --set hub=gcr.io/istio-testing --set values.pilot.env.ENABLE_GATEWAY_API_INFERENCE_EXTENSION=true
- 
If you run the Endpoint Picker (EPP) with the --secure-servingflag set totrue(the default mode), it is currently using a self-signed certificate. As a security measure, Istio does not trust self-signed certificates by default. As a temporary workaround, you can apply the destination rule to bypass TLS verification for EPP. A more secure TLS implementation in EPP is being discussed in Issue 582.kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/istio/destination-rule.yaml
- 
Deploy Gateway kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/istio/gateway.yamlConfirm that the Gateway was assigned an IP address and reports a Programmed=Truestatus:$ kubectl get gateway inference-gateway NAME CLASS ADDRESS PROGRAMMED AGE inference-gateway inference-gateway <MY_ADDRESS> True 22s
- 
Deploy the HTTPRoute kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/istio/httproute.yaml
- 
Confirm that the HTTPRoute status conditions include Accepted=TrueandResolvedRefs=True:kubectl get httproute llm-route -o yaml
Kgateway recently added support for inference extension as a technical preview. This means do not run Kgateway with inference extension in production environments. Refer to Issue 10411 for the list of caveats, supported features, etc.
- 
Requirements 
- 
Set the Kgateway version and install the Kgateway CRDs. KGTW_VERSION=v2.0.4 helm upgrade -i --create-namespace --namespace kgateway-system --version $KGTW_VERSION kgateway-crds oci://cr.kgateway.dev/kgateway-dev/charts/kgateway-crds
- 
Install Kgateway helm upgrade -i --namespace kgateway-system --version $KGTW_VERSION kgateway oci://cr.kgateway.dev/kgateway-dev/charts/kgateway --set inferenceExtension.enabled=true
- 
Deploy the Gateway kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/kgateway/gateway.yamlConfirm that the Gateway was assigned an IP address and reports a Programmed=Truestatus:$ kubectl get gateway inference-gateway NAME CLASS ADDRESS PROGRAMMED AGE inference-gateway kgateway <MY_ADDRESS> True 22s
- 
Deploy the HTTPRoute kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/kgateway/httproute.yaml
- 
Confirm that the HTTPRoute status conditions include Accepted=TrueandResolvedRefs=True:kubectl get httproute llm-route -o yaml
Agentgateway is a purpose-built proxy designed for AI workloads, and comes with native support for inference routing. Agentgateway integrates with Kgateway as it's control plane.
- 
Requirements 
- 
Set the Kgateway version and install the Kgateway CRDs. KGTW_VERSION=v2.0.4 helm upgrade -i --create-namespace --namespace kgateway-system --version $KGTW_VERSION kgateway-crds oci://cr.kgateway.dev/kgateway-dev/charts/kgateway-crds
- 
Install Kgateway helm upgrade -i --namespace kgateway-system --version $KGTW_VERSION kgateway oci://cr.kgateway.dev/kgateway-dev/charts/kgateway --set inferenceExtension.enabled=true --set agentGateway.enabled=true
- 
Deploy the Gateway kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/agentgateway/gateway.yamlConfirm that the Gateway was assigned an IP address and reports a Programmed=Truestatus:$ kubectl get gateway inference-gateway NAME CLASS ADDRESS PROGRAMMED AGE inference-gateway agentgateway <MY_ADDRESS> True 22s
- 
Deploy the HTTPRoute kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/agentgateway/httproute.yaml
- 
Confirm that the HTTPRoute status conditions include Accepted=TrueandResolvedRefs=True:kubectl get httproute llm-route -o yaml
Deploy InferenceObjective (Optional)¶
Deploy the sample InferenceObjective which allows you to specify priority of requests.
kubectl apply -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/inferenceobjective.yaml
Try it out¶
Wait until the gateway is ready.
IP=$(kubectl get gateway/inference-gateway -o jsonpath='{.status.addresses[0].value}')
PORT=80
curl -i ${IP}:${PORT}/v1/completions -H 'Content-Type: application/json' -d '{
"model": "food-review-1",
"prompt": "Write as if you were a critic: San Francisco",
"max_tokens": 100,
"temperature": 0
}'
Cleanup¶
The following instructions assume you would like to cleanup ALL resources that were created in this quickstart guide. Please be careful not to delete resources you'd like to keep.
- 
Uninstall the InferencePool, InferenceModel, and model server resources helm uninstall vllm-llama3-8b-instruct kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/inferenceobjective.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/vllm/cpu-deployment.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/vllm/gpu-deployment.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/vllm/sim-deployment.yaml --ignore-not-found kubectl delete secret hf-token --ignore-not-found
- 
Uninstall the Gateway API resources kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/gke/gateway.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/gke/healthcheck.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/gke/gcp-backend-policy.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/gke/httproute.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/istio/gateway.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/istio/destination-rule.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/istio/httproute.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/kgateway/gateway.yaml --ignore-not-found kubectl delete -f https://github.com/kubernetes-sigs/gateway-api-inference-extension/raw/main/config/manifests/gateway/kgateway/httproute.yaml --ignore-not-found
- 
Uninstall the Gateway API Inference Extension CRDs kubectl delete -k https://github.com/kubernetes-sigs/gateway-api-inference-extension/config/crd --ignore-not-found
- 
Choose one of the following options to cleanup the Inference Gateway. 
No further clean up is needed.
The following instructions assume you would like to clean up ALL Istio resources that were created in this quickstart guide.
- 
Uninstall All Istio resources istioctl uninstall -y --purge
- 
Remove the Istio namespace kubectl delete ns istio-system
The following instructions assume you would like to cleanup ALL Kgateway resources that were created in this quickstart guide.
- 
Uninstall Kgateway helm uninstall kgateway -n kgateway-system
- 
Uninstall the Kgateway CRDs. helm uninstall kgateway-crds -n kgateway-system
- 
Remove the Kgateway namespace. kubectl delete ns kgateway-system
The following instructions assume you would like to cleanup ALL Kgateway resources that were created in this quickstart guide.
- 
Uninstall Kgateway helm uninstall kgateway -n kgateway-system
- 
Uninstall the Kgateway CRDs. helm uninstall kgateway-crds -n kgateway-system
- 
Remove the Kgateway namespace. kubectl delete ns kgateway-system