README.md 3.0 KB
Newer Older
M
MRXLT 已提交
1 2 3 4 5 6 7
## 语义理解预测服务

示例中采用BERT模型进行语义理解预测,将文本表示为向量的形式,可以用来做进一步的分析和预测。

### 获取模型

示例中采用[Paddlehub](https://github.com/PaddlePaddle/PaddleHub)中的[BERT中文模型](https://www.paddlepaddle.org.cn/hubdetail?name=bert_chinese_L-12_H-768_A-12&en_category=SemanticModel)
M
fix doc  
MRXLT 已提交
8 9 10 11
请先安装paddlehub
```
pip install paddlehub
```
M
MRXLT 已提交
12 13
执行
```
M
fix doc  
MRXLT 已提交
14
python prepare_model.py 20
M
MRXLT 已提交
15
```
M
fix doc  
MRXLT 已提交
16 17 18
参数20表示BERT模型中的max_seq_len,即预处理后的样本长度。
生成server端配置文件与模型文件,存放在bert_seq20_model文件夹
生成client端配置文件,存放在bert_seq20_client文件夹
M
MRXLT 已提交
19

M
MRXLT 已提交
20 21 22 23 24 25 26 27
### 获取词典和样例数据

```
sh get_data.sh
```
脚本将下载中文词典vocab.txt和中文样例数据data-c.txt

### 启动RPC预测服务
M
MRXLT 已提交
28 29
执行
```
M
fix doc  
MRXLT 已提交
30
python -m paddle_serving_server.serve --model bert_seq20_model/ --port 9292  #启动cpu预测服务
M
MRXLT 已提交
31 32 33
```
或者
```
M
fix doc  
MRXLT 已提交
34
python -m paddle_serving_server_gpu.serve --model bert_seq20_model/ --port 9292 --gpu_ids 0 #在gpu 0上启动gpu预测服务
M
MRXLT 已提交
35 36 37 38 39
```

### 执行预测

```
M
fix doc  
MRXLT 已提交
40
cat data-c.txt | python bert_client.py 
M
MRXLT 已提交
41
```
M
fix doc  
MRXLT 已提交
42
启动client读取data-c.txt中的数据进行预测,预测结果为文本的向量表示(由于数据较多,脚本中没有讲输出进行打印),server端的地址在脚本中修改。
M
MRXLT 已提交
43 44 45 46 47 48 49

### 启动HTTP预测服务
```
 export CUDA_VISIBLE_DEVICES=0,1
```
通过环境变量指定gpu预测服务使用的gpu,示例中指定索引为0和1的两块gpu
```
M
fix doc  
MRXLT 已提交
50
 python bert_web_service.py bert_seq20_model/ 9292 #启动gpu预测服务
M
MRXLT 已提交
51 52
```
### 执行预测
M
MRXLT 已提交
53 54

```
M
MRXLT 已提交
55
curl -H "Content-Type:application/json" -X POST -d '{"words": "hello", "fetch":["pooled_output"]}' http://127.0.0.1:9292/bert/prediction
M
MRXLT 已提交
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
```

### Benchmark

模型:bert_chinese_L-12_H-768_A-12

设备:GPU V100 * 1

环境:CUDA 9.2,cudnn 7.1.4

测试中将样例数据中的1W个样本复制为10W个样本,每个client线程发送线程数分之一个样本,batch size为1,max_seq_len为20,时间单位为秒.

在client线程数为4时,预测速度可以达到432样本每秒。
由于单张GPU内部只能串行计算,client线程增多只能减少GPU的空闲时间,因此在线程数达到4之后,线程数增多对预测速度没有提升。

| client  thread num | prepro | client infer | op0   | op1    | op2  | postpro | total  |
| ------------------ | ------ | ------------ | ----- | ------ | ---- | ------- | ------ |
| 1                  | 3.05   | 290.54       | 0.37  | 239.15 | 6.43 | 0.71    | 365.63 |
| 4                  | 0.85   | 213.66       | 0.091 | 200.39 | 1.62 | 0.2     | 231.45 |
| 8                  | 0.42   | 223.12       | 0.043 | 110.99 | 0.8  | 0.098   | 232.05 |
| 12                 | 0.32   | 225.26       | 0.029 | 73.87  | 0.53 | 0.078   | 231.45 |
| 16                 | 0.23   | 227.26       | 0.022 | 55.61  | 0.4  | 0.056   | 231.9  |

总耗时变化规律如下:  
![bert benchmark](../../../doc/bert-benchmark-batch-size-1.png)