INSTALL.md 4.5 KB
Newer Older
W
wangguibao 已提交
1 2 3 4 5
# Install

## 系统需求

OS: Linux
W
wangguibao 已提交
6

M
MRXLT 已提交
7
CMake: (验证过的版本:3.2/3.5.2)
W
wangguibao 已提交
8

9 10 11 12
C++编译器 (验证过的版本:GCC 4.8.2/5.4.0)

python (验证过的版本:2.7)

M
MRXLT 已提交
13
Go编译器 (>=1.8 验证过的版本:1.9.2/1.12.0)
X
xulongteng 已提交
14 15

openssl & openssl-devel
W
wangguibao 已提交
16

M
MRXLT 已提交
17 18 19 20
curl-devel

bzip2-devel

W
wangguibao 已提交
21
## 编译
22

M
fix doc  
MRXLT 已提交
23
推荐使用Docker准备Paddle Serving编译环境。[Docker编译使用说明](./DOCKER.md)
W
wangguibao 已提交
24

M
fix doc  
MRXLT 已提交
25
以下命令将会下载Paddle Serving最新代码,并执行编译。
M
MRXLT 已提交
26

W
wangguibao 已提交
27
```shell
W
wangguibao 已提交
28
$ git clone https://github.com/PaddlePaddle/Serving.git
D
Dong Daxiang 已提交
29
$ cd Serving
W
wangguibao 已提交
30 31 32 33 34 35
$ mkdir build
$ cd build
$ cmake ..
$ make -j4
$ make install
```
W
wangguibao 已提交
36

W
wangguibao 已提交
37
`make install`将把目标产出放在/path/to/Paddle-Serving/build/output/目录下,目录结构:
W
wangguibao 已提交
38 39 40

```
.
W
wangguibao 已提交
41 42
|-- bin                             # Paddle Serving工具和protobuf编译插件pdcodegen所在目录
|-- conf
W
wangguibao 已提交
43
|-- demo                            # demo总目录
W
wangguibao 已提交
44 45 46
|   |-- client                      # Demo client端
|   |   |-- bert                    # bert模型客户端
|   |   |-- ctr_prediction          # CTR prediction模型客户端
W
wangguibao 已提交
47
|   |   |-- dense_format            # dense_format客户端
W
wangguibao 已提交
48 49 50 51 52 53 54 55 56 57 58 59 60 61
|   |   |-- echo                    # 最简单的echo service客户端
|   |   |-- echo_kvdb               # local KV读取demo客户端
|   |   |-- image_classification    # 图像分类任务客户端
|   |   |-- int64tensor_format      # int64tensor_format示例客户端
|   |   |-- sparse_format           # sparse_format示例客户端
|   |   `-- text_classification     # 文本分类任务示例客户端
|   |-- db_func
|   |-- db_thread
|   |-- kvdb_test
|   `-- serving                     # Demo serving端;该serving可同时响应所有demo client请求
|-- include                         # Paddle Serving发布的头文件
|-- lib                             # Paddle Serving发布的libs
`-- tool                            # Paddle Serving发布的工具目录

W
wangguibao 已提交
62 63 64
```

如要编写新的预测服务,请参考[从零开始写一个预测服务](CREATING.md)
W
wangguibao 已提交
65 66 67

# CMake编译选项说明

68 69
| 编译选项 | 说明 |
|----------|------|
W
Wang Guibao 已提交
70 71 72
| WITH_AVX | For configuring PaddlePaddle. Compile PaddlePaddle with AVX intrinsics |
| WITH_MKL | For configuring PaddlePaddle. Compile PaddlePaddle with MKLML library |
| WITH_GPU | For configuring PaddlePaddle. Compile PaddlePaddle with NVIDIA GPU |
73
| CUDNN_ROOT| For configuring PaddlePaddle. Define CuDNN library and header path |
74
| CLINET_ONLY | Compile client libraries and demos only |
75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117

## WITH_GPU选项

Paddle Serving通过PaddlePaddle预测库支持在GPU上做预测。WITH_GPU选项用于检测系统上CUDA/CUDNN等基础库,如检测到合适版本,在编译PaddlePaddle时就会编译出GPU版本的OP Kernel。

在裸机上编译Paddle Serving GPU版本,需要安装这些基础库:

- CUDA
- CuDNN
- NCCL2

这里要注意的是:
1) 编译Serving所在的系统上所安装的CUDA/CUDNN等基础库版本,需要兼容实际的GPU设备。例如,Tesla V100卡至少要CUDA 9.0。如果编译时所用CUDA等基础库版本过低,由于生成的GPU代码和实际硬件设备不兼容,会导致Serving进程无法启动,或出现coredump等严重问题。
2) 运行Paddle Serving的系统上安装与实际GPU设备兼容的CUDA driver,并安装与编译期所用的CUDA/CuDNN等版本兼容的基础库。如运行Paddle Serving的系统上安装的CUDA/CuDNN的版本低于编译时所用版本,可能会导致奇怪的cuda函数调用失败等问题。

以下是PaddlePaddle发布版本所使用的基础库版本匹配关系,供参考:

| | CUDA  | CuDNN | NCCL2 |
|-|-------|--------------------------|-------|
| CUDA 8 | 8.0.61 | CuDNN 7.1.2 for CUDA 8.0 | 2.1.4 |
| CUDA 9 | 9.0.176 | CuDNN 7.3.1 for CUDA 9.0| 2.2.12 |

### 如何让Paddle Serving编译系统探测到CuDNN库

从NVIDIA developer官网下载对应版本CuDNN并在本地解压后,在cmake编译命令中增加-DCUDNN_ROOT参数,指定CuDNN库所在路径:

```
$ pwd
/path/to/paddle-serving

$ mkdir build && cd build
$ cmake -DWITH_GPU=ON -DCUDNN_ROOT=/path/to/cudnn/cudnn_v7/cuda ..
```

### 如何让Paddle Serving编译系统探测到nccl库

从NVIDIA developer官网下载对应版本nccl2库并解压后,增加如下环境变量 (以nccl2.1.4为例):

```
$ export C_INCLUDE_PATH=/path/to/nccl2/cuda8/nccl_2.1.4-1+cuda8.0_x86_64/include:$C_INCLUDE_PATH
$ export CPLUS_INCLUDE_PATH=/path/to/nccl2/cuda8/nccl_2.1.4-1+cuda8.0_x86_64/include:$CPLUS_INCLUDE_PATH
$ export LD_LIBRARY_PATH=/path/to/nccl2/cuda8/nccl_2.1.4-1+cuda8.0_x86_64/lib/:$LD_LIBRARY_PATH
```