README.md 5.29 KB
Newer Older
zhuwenwen's avatar
zhuwenwen committed
1
2
# <div align="center"><strong>vLLM</strong></div>
## 简介
zhuwenwen's avatar
zhuwenwen committed
3
vLLM是一个快速且易于使用的LLM推理和服务库,使用PageAttention高效管理kv内存,Continuous batching传入请求,支持很多Hugging Face模型,如LLaMA & LLaMA-2、Qwen、Chatglm2 & Chatglm3等。
Woosuk Kwon's avatar
Woosuk Kwon committed
4

zhuwenwen's avatar
zhuwenwen committed
5
## 暂不支持的官方功能
zhuwenwen's avatar
zhuwenwen committed
6
- **量化推理**:目前不支持marlin的权重量化、kv-cache fp8推理方案
zhuwenwen's avatar
zhuwenwen committed
7
- **模块支持**:目前不支持Sliding window attention
zhuwenwen's avatar
zhuwenwen committed
8
9
10


## 支持模型结构列表
11
| 结构 | 模型 | FP16/BF16 | AWQ | GPTQ |
gaoqiong's avatar
gaoqiong committed
12
| :------: | :------: | :------: | :------: |:------: |
zhuwenwen's avatar
zhuwenwen committed
13
| LlamaForCausalLM      | Llama 3.1,Llama 3,Llama 2,Llama,Yi,Codellama,DeepSeek-R1-Distill-Llama     | Yes | Yes | Yes |  
14
| QWenLMHeadModel       | QWen,Qwen-VL                                                | Yes | Yes | Yes |
zhuwenwen's avatar
zhuwenwen committed
15
| Qwen2ForCausalLM      | QWen2,QWen1.5,CodeQwen1.5,DeepSeek-R1-Distill-Qwen,gte_Qwen2-1.5B-instruct          | Yes | Yes | Yes |
zhuwenwen's avatar
zhuwenwen committed
16
17
| Qwen3ForCausalLM      | QWen3                                                       | Yes | - | - |
| Qwen3MoeForCausalLM   | QWen3MoE                                                    | Yes | - | - |
18
| ChatGLMModel          | glm-4v-9b,chatglm3,chatglm2                                 | Yes | No  | Yes |
zhuwenwen's avatar
zhuwenwen committed
19
| DeepseekForCausalLM   | Deepseek                                                    | Yes | No  | -   |
20
| DeepseekV2ForCausalLM | DeepSeek-V2                                                 | Yes | No  | -   |
zhuwenwen's avatar
zhuwenwen committed
21
| DeepseekV3ForCausalLM | DeepSeek-V3                                                 | Yes | Yes | -   |
22
| BaiChuanForCausalLM   | Baichuan2,Baichuan                                          | Yes | Yes | -   |
zhuwenwen's avatar
zhuwenwen committed
23
| BloomForCausalLM      | BLOOM                                                       | Yes | No  | Yes |
24
25
| InternLMForCausalLM   | InternLM                                                    | Yes | No  | -   |
| InternLM2ForCausalLM  | InternLM2                                                   | Yes | No  | -   |
zhuwenwen's avatar
zhuwenwen committed
26
| FalconForCausalLM     | falcon                                                      | Yes | No  | Yes |
zhuwenwen's avatar
zhuwenwen committed
27
| TeleChat2ForCausalLM  | TeleChat2                                                   | Yes | No  | -   |
28
29
30
31
32
33
34
35
| MiniCPMForCausalLM    | MiniCPM                                                     | Yes | No  | -   |
| MiniCPM3ForCausalLM   | MiniCPM3                                                    | Yes | No  | -   |
| MixtralForCausalLM    | Mixtral-8x7B,Mixtral-8x7B-Instruct                          | Yes | No  | -   |
| Qwen2MoeForCausalLM                 | Qwen2-57B-A14B,Qwen2-57B-A14B-Instruct        | Yes | No  | -   |
| LlavaForConditionalGeneration       | LLaMA,LLaMA-2,LLaMA-3                         | Yes | No  | -   |
| Qwen2VLForConditionalGeneration     | Qwen2-VL                                      | Yes | No  | Yes |
| MiniCPMV                            | MiniCPM-V                                     | Yes | No  | -   |
| Phi3VForCausalLM                    | Phi-3.5-vision                                | Yes | No  | -   |
zhuwenwen's avatar
zhuwenwen committed
36
37
38
| BertModel                           | bge-large-zh-v1.5                             | Yes | No  | -   |
| XLMRobertaModel                     | bge-m3                                        | Yes | No  | -   |
| XLMRobertaForSequenceClassification | bge-reranker-v2-m3                            | Yes | No  | -   |
zhuwenwen's avatar
zhuwenwen committed
39
40


zhuwenwen's avatar
zhuwenwen committed
41
42
43
44
45
## 安装
vLLM支持
+ Python 3.9.
+ Python 3.10.
+ Python 3.11.
zhuwenwen's avatar
zhuwenwen committed
46
+ Python 3.12.
Woosuk Kwon's avatar
Woosuk Kwon committed
47

zhuwenwen's avatar
zhuwenwen committed
48
### 使用源码编译方式安装
Woosuk Kwon's avatar
Woosuk Kwon committed
49

zhuwenwen's avatar
zhuwenwen committed
50
#### 编译环境准备
zhuwenwen's avatar
zhuwenwen committed
51
提供2种环境准备方式:
Woosuk Kwon's avatar
Woosuk Kwon committed
52

zhuwenwen's avatar
zhuwenwen committed
53
1. 基于光源pytorch2.4.1基础镜像环境:根据pytorch2.4.1、python、dtk及系统下载对应的镜像版本。
54

zhuwenwen's avatar
zhuwenwen committed
55
2. 基于现有python环境:安装pytorch2.4.1,pytorch whl包下载目录:[https://cancon.hpccube.com:65024/4/main/pytorch](https://cancon.hpccube.com:65024/4/main/pytorch),根据python、dtk版本,下载对应pytorch2.4.1的whl包。安装命令如下:
zhuwenwen's avatar
zhuwenwen committed
56
57
58
59
```shell
pip install torch* (下载的torch的whl包)
pip install setuptools wheel
```
Zhuohan Li's avatar
Zhuohan Li committed
60

zhuwenwen's avatar
zhuwenwen committed
61
62
#### 源码编译安装
```shell
zhuwenwen's avatar
zhuwenwen committed
63
git clone http://developer.hpccube.com/codes/OpenDAS/vllm.git # 根据需要的分支进行切换
Zhuohan Li's avatar
Zhuohan Li committed
64
```
zhuwenwen's avatar
zhuwenwen committed
65
安装依赖:
zhuwenwen's avatar
zhuwenwen committed
66
```shell
zhuwenwen's avatar
zhuwenwen committed
67
pip install -r requirements/rocm.txt
zhuwenwen's avatar
zhuwenwen committed
68
```
zhuwenwen's avatar
zhuwenwen committed
69
- 提供2种源码编译方式(进入vllm目录):
zhuwenwen's avatar
zhuwenwen committed
70
71
```
1. 编译whl包并安装
zhuwenwen's avatar
zhuwenwen committed
72
python setup.py bdist_wheel 
zhuwenwen's avatar
zhuwenwen committed
73
74
cd dist
pip install vllm*
Zhuohan Li's avatar
Zhuohan Li committed
75

zhuwenwen's avatar
zhuwenwen committed
76
2. 源码编译安装
zhuwenwen's avatar
zhuwenwen committed
77
python3 setup.py install (若调试,可使用python3 setup.py develop)
zhuwenwen's avatar
zhuwenwen committed
78
```
zhuwenwen's avatar
zhuwenwen committed
79
若需要添加git号,设置环境变量: export ADD_GIT_VERSION=1
Zhuohan Li's avatar
Zhuohan Li committed
80

zhuwenwen's avatar
zhuwenwen committed
81
#### 运行基础环境准备
zhuwenwen's avatar
zhuwenwen committed
82
1、使用上面基于光源pytorch2.4.1基础镜像环境
zhuwenwen's avatar
zhuwenwen committed
83

zhuwenwen's avatar
zhuwenwen committed
84
2、根据pytorch2.4.1、python、dtk及系统下载对应的依赖包:
zhuwenwen's avatar
zhuwenwen committed
85
86
- triton:[https://cancon.hpccube.com:65024/4/main/triton](https://cancon.hpccube.com:65024/4/main/triton/)
- flash_attn: [https://cancon.hpccube.com:65024/4/main/flash_attn](https://cancon.hpccube.com:65024/4/main/flash_attn)
gaoqiong's avatar
gaoqiong committed
87
- lmslim: [https://cancon.hpccube.com:65024/4/main/lmslim](https://cancon.hpccube.com:65024/4/main/lmslim)
zhuwenwen's avatar
zhuwenwen committed
88

zhuwenwen's avatar
zhuwenwen committed
89
#### 注意事项
zhuwenwen's avatar
zhuwenwen committed
90
+ 若使用 pip install 下载安装过慢,可添加源:-i https://pypi.tuna.tsinghua.edu.cn/simple/
91

zhuwenwen's avatar
zhuwenwen committed
92
## 验证
zhuwenwen's avatar
zhuwenwen committed
93
- python -c "import vllm; print(vllm.\_\_version__)",版本号与官方版本同步,查询该软件的版本号,例如0.8.5;
Woosuk Kwon's avatar
Woosuk Kwon committed
94

zhuwenwen's avatar
zhuwenwen committed
95
96
## Known Issue
-
Woosuk Kwon's avatar
Woosuk Kwon committed
97

zhuwenwen's avatar
zhuwenwen committed
98
99
100
## 参考资料
- [README_ORIGIN](README_ORIGIN.md)
- [https://github.com/vllm-project/vllm](https://github.com/vllm-project/vllm)