✨ ZhiLight ✨is a highly optimized LLM inference engine developed by Zhihu and ModelBest Inc. The "Zhi" in its name stands for Zhihu. ZhiLight can accelerate the inference of models like Llama and its variants, especially on PCIe-based GPUs. Compared to mainstream open-source inference engines, for example, vllm, it has significant performance advantages.
- Asynchronous OpenAI compatible interface adapted from vllm
- Custom defined tensor and unified global memory management
- 🔥 Encode and all-reduce overlap, we named "dual streams"
- Host all-reduce based on SIMD instructions
- Optimized fused kernels, qkv, residual & layernorm etc.
- 🔥 Fused batch attention for decoding based on tensor core instructions
- Support TP and PP on one node, TP is recommended
- Support dynamic batch
- Support flashatten prefill
- Support chunked prefill
- Support prefix cache
- Support Native INT8/SmoothQuant/FP8/AWQ/GPTQ quantization
- Support Marlin kernel for GPTQ
- Support MoE, DeepseekV2 MoE and DeepseekV2 MLA
- Support Llama/Llama2, Mixtral, Qwen2 series and similar models
# Concurrently compile the wheel package, and turn off the unit test
CMAKE_BUILD_PARALLEL_LEVEL=32 TESTING=0 python setup.py bdist_wheel
# Compile with ninja backend
CMAKE_GENERATER="Ninja" python setup.py bdist_wheel
# Install directly
cd ./ZhiLight && pip install -e .
# Start OpenAI compatible server
python -m zhilight.server.openai.entrypoints.api_server [options]
ZhiLight only depends on the CUDA runtime, cuBLAS, NCCL, and a few Python packages in requirements.txt. You can use the image below for running or building it. You can also directly refer to docker/Dockerfile.
docker pull ghcr.io/zhihu/zhilight/zhilight:0.4.8-cu124
We conducted performance reviews on various mainstream NVIDIA GPUs with different model sizes and precisions. For dense models ranging from 2B to 110B parameters on PCIe devices, ZhiLight demonstrates significant performance advantages compared to mainstream open-source inference engines.
Test Description:
- Test purpose is to demonstrate performance, applicable scenarios and limitations
- Test dataset contains approximately 3.7k prompts
- Test metrics include:
- QPS: Queries Per Second
- TTFT (Time To First Token): First token generation latency
- TPOT (Time Per Output Token): Generation latency per output token
- Test environments include:
- AD102 PCIe : Consumer-grade GPU for experimental research
- A800: Data center GPU for production deployment
- Test models include:
- Large-scale models: Qwen1.5-110B, Qwen2-72B, LLama-3.1-70B
- Medium-scale models: Qwen2.5-14B, Llama-3.1-8B, Minicpm-2B
- Compared inference engines include:
- vLLM
- SGLang
- ZhiLight
- NVIDIA AD102 PCIe * 1
Inference Engine | QPS | TTFT Mean | TTFT P95 | TPOT Mean | TPOT P95 |
---|---|---|---|---|---|
vLLM | 1.67 | 527.55 | 1062.96 | 16.71 | 31.95 |
SGLang | 1.67 | 466.19 | 1181.5 | 33.96 | 59.44 |
ZhiLight | 1.67 | 434.64 | 989.03 | 26.1 | 61.14 |
- NVIDIA AD102 PCIe * 4
Inference Engine | QPS | TTFT Mean | TTFT P95 | TPOT Mean | TPOT P95 |
---|---|---|---|---|---|
vLLM | 0.18 | 3493.97 | 6852.07 | 35.47 | 61.74 |
SGLang | 0.18 | 2276.1 | 3820.7 | 38.12 | 65.16 |
ZhiLight | 0.18 | 1111.8 | 1882.5 | 26.75 | 41.81 |
- NVIDIA A800 * 4
Inference Engine | QPS | TTFT Mean | TTFT P95 | TPOT Mean | TPOT P95 |
---|---|---|---|---|---|
vLLM | 0.18 | 1457.65 | 2136.5 | 22.14 | 28.96 |
SGLang | 0.36 | 1113.06 | 1850.57 | 30.41 | 43.65 |
ZhiLight | 0.18 | 1227.37 | 1968.95 | 31.95 | 48.53 |
- NVIDIA AD102 PCIe * 4
Inference Engine | QPS | TTFT Mean | TTFT P95 | TPOT Mean | TPOT P95 |
---|---|---|---|---|---|
vLLM | 0.09 | 3085.74 | 4274.03 | 30.34 | 44.08 |
SGLang | 0.09 | 2418.56 | 3187.73 | 31.39 | 53.1 |
ZhiLight | 0.18 | 1671.38 | 2669.82 | 39.68 | 64.35 |
- NVIDIA A800 * 4
Inference Engine | QPS | TTFT Mean | TTFT P95 | TPOT Mean | TPOT P95 |
---|---|---|---|---|---|
vLLM | 0.09 | 1899.07 | 2719.59 | 23.8 | 33.02 |
SGLang | 0.18 | 1514.49 | 2135.75 | 28.5 | 47.28 |
ZhiLight | 0.1 | 1574.85 | 2086.8 | 27.07 | 38.82 |
more benchmarks can be found in benchmarks.md
Apache License 2.0