Skip to main content

Documentation Index

Fetch the complete documentation index at: https://gcore.com/docs/llms.txt

Use this file to discover all available pages before exploring further.

Gcore Everywhere Inference runs custom AI models from container images. This article covers containerizing a model with vLLM or Diffusers, pushing the image to a registry, and deploying it.

Train, test, and optimize the model for inference

Before packaging a model into a container, train, validate, and optimize it for inference. Apply techniques such as quantization, pruning, or distillation to reduce computational load.

Containerization

To deploy an AI model, it must be packaged into a container image that meets industry standards. While there are no strict structural requirements, the image must be compatible with the target registry and deployment environment.

vLLM

vLLM is a library for large language model inference and serving. It features PagedAttention for memory efficiency, continuous batching, and acceleration via CUDA/HIP graphs and FlashAttention. It supports speculative decoding, chunked prefill, and multiple quantization formats (GPTQ, AWQ, INT4, INT8, FP8).

Step 1. Choose a base image

vLLM integrates with Hugging Face and other model repositories. The latest vLLM images are available in the Docker Hub repository. Use the official vLLM base image that supports the required model architecture:
FROM vllm/vllm-openai:latest 
For custom models, modify the image during the build process.

Step 2. Modify and build the image

To include a specific model from Hugging Face, update the container with the required model and build the image:
FROM vllm/vllm-openai:latest 
RUN huggingface-cli download state-spaces/mamba-130m-hf 
ENTRYPOINT ["vllm", "serve", "state-spaces/mamba-130m-hf", "--host", "0.0.0.0", "--port", "80"]
Then build the container:
docker build -t <IMAGE>:<TAG> .
Build the specific model from Hugging Face
On macOS with Apple Silicon (M chips), use:
docker buildx build --platform linux/amd64 -t <IMAGE>:<TAG> .
This forces the linux/amd64 architecture, preventing compatibility issues on x86-64 servers.

Step 3. Push to registry

After building the image, push it to a registry:
docker tag <IMAGE> <REGISTRY>/<REPOSITORY>:<TAG>
docker push <REGISTRY>/<REPOSITORY>:<TAG>
Tag and push the image to a registry
The model is now embedded in the container and available for inference. The Gcore Container Registry can be used to store and manage images for deployment.

Configuration options

vLLM provides options to adjust performance and behavior. Notable configurations include:
ParameterExampleDescription
--trust-remote-codevllm serve state-spaces/mamba-130m-hf --trust-remote-code --host 0.0.0.0 --port 80Allows running models that rely on custom Python code from Hugging Face’s Model Hub. By default, this setting is False, meaning vLLM will not execute any remote code unless explicitly allowed.
--max-model-lenvllm serve state-spaces/mamba-130m-hf --max-model-len 2048 --host 0.0.0.0 --port 80Sets the maximum number of tokens the model can process in a single request. This helps control memory usage and ensures proper processing of long texts.
--tensor-parallel-sizevllm serve state-spaces/mamba-130m-hf --tensor-parallel-size 4 --host 0.0.0.0 --port 80Splits the model tensors across multiple GPUs to balance memory usage and allow larger models to fit into available hardware.
--enable-prefix-cachingvllm serve state-spaces/mamba-130m-hf --enable-prefix-caching --host 0.0.0.0 --port 80Improves efficiency by caching repeated prompt prefixes to reduce redundant computations and speed up inference for similar queries.
--served-model-namevllm serve state-spaces/mamba-130m-hf --served-model-name custom-model --host 0.0.0.0 --port 80Specifies a custom name for the deployed model, making it easier to reference in API requests.
--enable-reasoningvllm serve deepseek-ai/DeepSeek-R1-Distill-Qwen-1.5B --enable-reasoning --reasoning-parser deepseek_r1 --host 0.0.0.0 --port 80Enables reasoning mode, allowing models to provide intermediate reasoning steps for better insight into the decision-making process. Requires --reasoning-parser to extract reasoning content from the model output.
Combine these parameters in a single command. The vLLM documentation provides a full list of configuration options and CLI commands.

Diffusers

Diffusers is a library for running diffusion-based image generation models. Unlike vLLM, it lacks a built-in serving interface, so inference code must be implemented separately. The environment must include CUDA, cuDNN, and PyTorch. Models are available on the Hugging Face model hub.

Step 1. Choose a base image

Instead of building from scratch, use official images from the NVIDIA NGC AI Catalog or PyTorch. The following Dockerfile starts with a PyTorch base image and installs Diffusers:
FROM pytorch/pytorch:2.6.0-cuda11.8-cudnn9-devel 
RUN pip install diffusers 
At this stage, the container does not yet have inference functionality.

Step 2. Implement an inference API

An API must be implemented since diffusers don’t include a built-in inference server. The following script loads a Stable Diffusion model, accepts a text prompt via API, and returns a generated image.
from fastapi import FastAPI, Request
from diffusers import StableDiffusionPipeline
import base64
from io import BytesIO
from PIL import Image


app = FastAPI()
pipe = StableDiffusionPipeline.from_pretrained("stabilityai/stable-diffusion-2-1").to("cuda")


@app.post("/generate")
async def generate_image(request: Request):
	data = await request.json()
	prompt = data.get("prompt", "")
	n = data.get("n", 1)
	images = pipe(prompt).images[:n]
	encoded_images = []
	for img in images:
    		buffered = BytesIO()
    		img.save(buffered, format="PNG")
   		encoded_images.append({"b64_json": base64.b64encode /
    (buffered.getvalue()).decode("utf-8")})

	return {"data": encoded_images}
This API allows applications to send HTTP requests for on-demand image generation.

Step 3. Create a Dockerfile

The Dockerfile includes Diffusers and the API service. If the model requires authentication, provide the token in the Dockerfile.
FROM pytorch/pytorch:2.6.0-cuda11.8-cudnn9-devel 
WORKDIR /app 
RUN pip install --no-cache-dir diffusers fastapi uvicorn transformers 
COPY inference.py /app/inference.py 
CMD ["uvicorn", "inference:app", "--host", "0.0.0.0", "--port", "80"] 
This setup prepares the model and API server to start automatically after deployment.

Step 4. Push to registry

After building the container, push it to a registry for deployment:
docker build -t <IMAGE>:<TAG> .
docker tag <IMAGE> <REGISTRY>/<REPOSITORY>
docker push <REGISTRY>/<REPOSITORY>
Tag and push the image with diffusers library to a registry
Assign a new tag when updating the container to prevent Kubernetes from using outdated images.

Deployment

After uploading the container to a registry, deploy it using the Deploy a custom model guide. During deployment, enter the model image URL from the registry. For a private registry, provide authentication credentials — URL, username, and password — as described in adding a container image registry.
Custom model deployment form showing the Image URL field
The deployment provides an endpoint for sending requests to the model.