DESIGN_DOC.md 3.5 KB
Newer Older
D
Dong Daxiang 已提交
1 2 3 4
# Paddle Serving设计文档

## 1. 整体设计目标

D
Dong Daxiang 已提交
5
- 长期使命:Paddle Serving是一个PaddlePaddle开源的在线服务框架,长期目标就是围绕着人工智能落地的最后一公里提供越来越专业、可靠、易用的服务。
D
Dong Daxiang 已提交
6

D
Dong Daxiang 已提交
7
- 工业级:为了达到工业级深度学习模型在线部署的要求,
D
Dong Daxiang 已提交
8 9
Paddle Serving提供很多大规模场景需要的部署功能:1)分布式稀疏参数索引功能;2)高并发底层通信能力;3)模型管理、在线A/B流量测试、模型热加载。

D
Dong Daxiang 已提交
10
- 简单易用:为了让使用Paddle的用户能够以极低的成本部署模型,PaddleServing设计了一套与Paddle训练框架无缝打通的预测部署API,普通模型可以使用一行命令进行服务部署。
D
Dong Daxiang 已提交
11

D
Dong Daxiang 已提交
12
- 功能扩展:当前,Paddle Serving支持C++、Python、Golang的客户端,未来也会面向不同类型的客户新增多种语言的客户端。在Paddle Serving的框架设计方面,尽管当前Paddle Serving以支持Paddle模型的部署为核心功能,
D
Dong Daxiang 已提交
13
用户可以很容易嵌入其他的机器学习库部署在线预测。
D
Dong Daxiang 已提交
14 15 16

## 2. 模块设计与实现

D
Dong Daxiang 已提交
17
### 2.1 Python API接口设计
D
Dong Daxiang 已提交
18

D
Dong Daxiang 已提交
19 20 21 22 23 24 25 26
#### 2.1.1 训练模型的保存
Paddle的模型预测需要重点关注的内容:1)模型的输入变量;2)模型的输出变量;3)模型结构和模型参数。Paddle Serving Python API提供用户可以在训练过程中保存模型的接口,并将Paddle Serving在部署阶段需要保存的配置打包保存,一个示例如下:
``` python
import paddle_serving_client.io as serving_io
serving_io.save_model("serving_model", "client_conf",
                      {"words": data}, {"prediction": prediction},
                      fluid.default_main_program())
```
D
Dong Daxiang 已提交
27 28 29 30

#### 2.1.2 服务端模型加载

#### 2.1.3 客户端访问API
D
Dong Daxiang 已提交
31

D
Dong Daxiang 已提交
32
### 2.2 底层通信机制
D
Dong Daxiang 已提交
33
Paddle Serving采用[baidu-rpc](https://github.com/apache/incubator-brpc)进行底层的通信。baidu-rpc是百度开源的一款PRC通信库,具有高并发、低延时等特点,已经支持了包括百度在内上百万在线预估实例、上千个在线预估服务,稳定可靠。Paddle Serving底层采用baidu-rpc的另一个原因是深度学习模型的远程调用服务通常对延时比较敏感,需要采用一款延时较低的rpc。
D
Dong Daxiang 已提交
34

D
Dong Daxiang 已提交
35
### 2.3 核心执行引擎
D
Dong Daxiang 已提交
36 37 38 39
Paddle Serving的核心执行引擎是一个有向无环图,图中的每个节点代表预估服务的一个环节,例如计算模型预测打分就是其中一个环节。有向无环图有利于可并发节点充分利用部署实例内的计算资源,缩短延时。一个例子,当同一份输入需要送入两个不同的模型进行预估,并将两个模型预估的打分进行加权求和时,两个模型的打分过程即可以通过有向无环图的拓扑关系并发。

### 2.4 微服务插件模式
由于Paddle Serving底层采用基于C++的通信组件,并且核心框架也是基于C/C++编写,当用户想要在服务端定义复杂的前处理与后处理逻辑时,一种办法是修改Paddle Serving底层框架,重新编译源码。另一种方式可以通过在服务端嵌入轻量级的Web服务,通过在Web服务中实现更复杂的预处理逻辑,从而搭建一套逻辑完整的服务。当访问量超过了Web服务能够接受的范围,开发者有足够的理由开发一些高性能的C++预处理逻辑,并嵌入到Serving的原生服务库中。
D
Dong Daxiang 已提交
40 41 42 43 44 45

## 3. 工业级特性

### 3.1 分布式稀疏索引

### 3.2 模型管理、在线A/B流量测试、模型热加载
D
Dong Daxiang 已提交
46 47 48

## 4. 用户类型