Supported Models#
Generative Models#
Llama / Llama 2 / Llama 3 / Llama 3.1 / Llama 3.2
Mistral / Mixtral / Mistral NeMo
Gemma / Gemma 2
Qwen / Qwen 2 / Qwen 2 MoE / Qwen 2 VL
DeepSeek / DeepSeek 2 / DeepSeek 3
OLMoE
-
python3 -m sglang.launch_server --model-path lmms-lab/llava-onevision-qwen2-7b-ov --port=30000 --chat-template=chatml-llava
python3 -m sglang.launch_server --model-path lmms-lab/llava-onevision-qwen2-72b-ov --port=30000 --tp-size=8 --chat-template=chatml-llava
Query the server with the OpenAI Vision API. See examples at test/srt/test_vision_openai_server.py
LLaVA 1.5 / 1.6 / NeXT
python -m sglang.launch_server --model-path lmms-lab/llama3-llava-next-8b --port=30000 --tp-size=1 --chat-template=llava_llama_3
python -m sglang.launch_server --model-path lmms-lab/llava-next-72b --port=30000 --tp-size=8 --chat-template=chatml-llava
Query the server with the OpenAI Vision API. See examples at test/srt/test_vision_openai_server.py
Yi-VL
StableLM
Command-R
DBRX
Grok
ChatGLM
InternLM 2
Exaone 3
BaiChuan2
MiniCPM / MiniCPM 3
XVERSE / XVERSE MoE
SmolLM
GLM-4
Phi-3-Small
IBM Granite 3
Embedding Models#
LlamaEmbeddingModel
Mistral embedding models
QWen embedding models
python -m sglang.launch_server --model-path Alibaba-NLP/gte-Qwen2-7B-instruct --is-embedding
Reward Models#
LlamaForSequenceClassification
python -m sglang.launch_server --model-path Skywork/Skywork-Reward-Llama-3.1-8B-v0.2 --is-embedding
Gemma2ForSequenceClassification
python -m sglang.launch_server --model-path Skywork/Skywork-Reward-Gemma-2-27B-v0.2 --is-embedding
InternLM2ForRewardModel
python -m sglang.launch_server --model-path internlm/internlm2-7b-reward --is-embedding --trust-remote-code
How to Support a New Model#
To support a new model in SGLang, you only need to add a single file under SGLang Models Directory. You can learn from existing model implementations and create new files for the new models. For most models, you should be able to find a similar model to start with (e.g., starting from Llama).
Test the correctness#
Interactive debugging#
For interactive debugging, you can compare the outputs of huggingface/transformers and SGLang. The following two commands should give the same text output and very similar prefill logits.
Get the reference output by
python3 scripts/playground/reference_hf.py --model [new model]
Get the SGLang output by
python3 -m sglang.bench_one_batch --correct --model [new model]
Add the model to the test suite#
To make sure the new model is well maintained in the future, it is better to add it to the test suite.
You can add it to the ALL_OTHER_MODELS
list in the test_generation_models.py and run the following command to test it.
For example, if the model is Qwen/Qwen2-1.5B
ONLY_RUN=Qwen/Qwen2-1.5B python3 -m unittest test_generation_models.TestGenerationModels.test_others
Port a model from vLLM to SGLang#
Another valuable resource is the vLLM Models Directory. vLLM has extensive coverage of models, and SGLang reuses vLLM’s interface and some layers to implement the models. This similarity makes it easy to port many models from vLLM to SGLang.
To port a model from vLLM to SGLang, you can compare these two files SGLang Llama Implementation and vLLM Llama Implementation. This comparison will help you understand how to convert a model implementation from vLLM to SGLang. The major difference is the replacement of Attention with RadixAttention. The other parts are almost identical. Specifically,
Replace vllm’s
Attention
withRadixAttention
. Note that you need to passlayer_id
all the way toRadixAttention
.Replace vllm’s
LogitsProcessor
with SGLang’sLogitsProcessor
.Replace other vLLM layers with SGLang layers (e.g.,
RMSNorm
,SiluAndMul
).Remove
Sample
.Change
forward()
functions, and addforward_batch
.Add
EntryClass
at the end.
Registering an external model implementation#
In addition to the methods described above, you can also register your new model with the ModelRegistry
before launching the server. This approach is useful if you want to integrate your model without needing to modify the source code.
Here is how you can do it:
from sglang.srt.models.registry import ModelRegistry
from sglang.srt.server import launch_server
# for a single model, you can add it to the registry
ModelRegistry.models[model_name] = model_class
# for multiple models, you can imitate the import_model_classes() function in sglang/srt/models/registry.py
from functools import lru_cache
@lru_cache()
def import_new_model_classes():
model_arch_name_to_cls = {}
...
return model_arch_name_to_cls
ModelRegistry.models.update(import_new_model_classes())
launch_server(server_args)