Merge pull request #1374 from WenmuZhou/docker
[Dygraph] add docker depoly
This commit is contained in:
commit
e65339eca7
|
@ -0,0 +1,54 @@
|
||||||
|
English | [简体中文](README_cn.md)
|
||||||
|
|
||||||
|
## Introduction
|
||||||
|
Many users hope package the PaddleOCR service into a docker image, so that it can be quickly released and used in the docker or k8s environment.
|
||||||
|
|
||||||
|
This page provides some standardized code to achieve this goal. You can quickly publish the PaddleOCR project into a callable Restful API service through the following steps. (At present, the deployment based on the HubServing mode is implemented first, and author plans to increase the deployment of the PaddleServing mode in the futrue)
|
||||||
|
|
||||||
|
## 1. Prerequisites
|
||||||
|
|
||||||
|
You need to install the following basic components first:
|
||||||
|
a. Docker
|
||||||
|
b. Graphics driver and CUDA 10.0+(GPU)
|
||||||
|
c. NVIDIA Container Toolkit(GPU,Docker 19.03+ can skip this)
|
||||||
|
d. cuDNN 7.6+(GPU)
|
||||||
|
|
||||||
|
## 2. Build Image
|
||||||
|
a. Goto Dockerfile directory(ps:Need to distinguish between cpu and gpu version, the following takes cpu as an example, gpu version needs to replace the keyword)
|
||||||
|
```
|
||||||
|
cd deploy/docker/hubserving/cpu
|
||||||
|
```
|
||||||
|
c. Build image
|
||||||
|
```
|
||||||
|
docker build -t paddleocr:cpu .
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3. Start container
|
||||||
|
a. CPU version
|
||||||
|
```
|
||||||
|
sudo docker run -dp 8868:8868 --name paddle_ocr paddleocr:cpu
|
||||||
|
```
|
||||||
|
b. GPU version (base on NVIDIA Container Toolkit)
|
||||||
|
```
|
||||||
|
sudo nvidia-docker run -dp 8868:8868 --name paddle_ocr paddleocr:gpu
|
||||||
|
```
|
||||||
|
c. GPU version (Docker 19.03++)
|
||||||
|
```
|
||||||
|
sudo docker run -dp 8868:8868 --gpus all --name paddle_ocr paddleocr:gpu
|
||||||
|
```
|
||||||
|
d. Check service status(If you can see the following statement then it means completed:Successfully installed ocr_system && Running on http://0.0.0.0:8868/)
|
||||||
|
```
|
||||||
|
docker logs -f paddle_ocr
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4. Test
|
||||||
|
a. Calculate the Base64 encoding of the picture to be recognized (if you just test, you can use a free online tool, like:https://freeonlinetools24.com/base64-image/)
|
||||||
|
b. Post a service request(sample request in sample_request.txt)
|
||||||
|
|
||||||
|
```
|
||||||
|
curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"Input image Base64 encode(need to delete the code 'data:image/jpg;base64,')\"]}" http://localhost:8868/predict/ocr_system
|
||||||
|
```
|
||||||
|
c. Get resposne(If the call is successful, the following result will be returned)
|
||||||
|
```
|
||||||
|
{"msg":"","results":[[{"confidence":0.8403433561325073,"text":"约定","text_region":[[345,377],[641,390],[634,540],[339,528]]},{"confidence":0.8131805658340454,"text":"最终相遇","text_region":[[356,532],[624,530],[624,596],[356,598]]}]],"status":"0"}
|
||||||
|
```
|
|
@ -0,0 +1,53 @@
|
||||||
|
[English](README.md) | 简体中文
|
||||||
|
|
||||||
|
## Docker化部署服务
|
||||||
|
在日常项目应用中,相信大家一般都会希望能通过Docker技术,把PaddleOCR服务打包成一个镜像,以便在Docker或k8s环境里,快速发布上线使用。
|
||||||
|
|
||||||
|
本文将提供一些标准化的代码来实现这样的目标。大家通过如下步骤可以把PaddleOCR项目快速发布成可调用的Restful API服务。(目前暂时先实现了基于HubServing模式的部署,后续作者计划增加PaddleServing模式的部署)
|
||||||
|
|
||||||
|
## 1.实施前提准备
|
||||||
|
|
||||||
|
需要先完成如下基本组件的安装:
|
||||||
|
a. Docker环境
|
||||||
|
b. 显卡驱动和CUDA 10.0+(GPU)
|
||||||
|
c. NVIDIA Container Toolkit(GPU,Docker 19.03以上版本可以跳过此步)
|
||||||
|
d. cuDNN 7.6+(GPU)
|
||||||
|
|
||||||
|
## 2.制作镜像
|
||||||
|
a.切换至Dockerfile目录(注:需要区分cpu或gpu版本,下文以cpu为例,gpu版本需要替换一下关键字即可)
|
||||||
|
```
|
||||||
|
cd deploy/docker/hubserving/cpu
|
||||||
|
```
|
||||||
|
c.生成镜像
|
||||||
|
```
|
||||||
|
docker build -t paddleocr:cpu .
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.启动Docker容器
|
||||||
|
a. CPU 版本
|
||||||
|
```
|
||||||
|
sudo docker run -dp 8868:8868 --name paddle_ocr paddleocr:cpu
|
||||||
|
```
|
||||||
|
b. GPU 版本 (通过NVIDIA Container Toolkit)
|
||||||
|
```
|
||||||
|
sudo nvidia-docker run -dp 8868:8868 --name paddle_ocr paddleocr:gpu
|
||||||
|
```
|
||||||
|
c. GPU 版本 (Docker 19.03以上版本,可以直接用如下命令)
|
||||||
|
```
|
||||||
|
sudo docker run -dp 8868:8869 --gpus all --name paddle_ocr paddleocr:gpu
|
||||||
|
```
|
||||||
|
d. 检查服务运行情况(出现:Successfully installed ocr_system和Running on http://0.0.0.0:8868 等信息,表示运行成功)
|
||||||
|
```
|
||||||
|
docker logs -f paddle_ocr
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.测试服务
|
||||||
|
a. 计算待识别图片的Base64编码(如果只是测试一下效果,可以通过免费的在线工具实现,如:http://tool.chinaz.com/tools/imgtobase/)
|
||||||
|
b. 发送服务请求(可参见sample_request.txt中的值)
|
||||||
|
```
|
||||||
|
curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"填入图片Base64编码(需要删除'data:image/jpg;base64,')\"]}" http://localhost:8868/predict/ocr_system
|
||||||
|
```
|
||||||
|
c. 返回结果(如果调用成功,会返回如下结果)
|
||||||
|
```
|
||||||
|
{"msg":"","results":[[{"confidence":0.8403433561325073,"text":"约定","text_region":[[345,377],[641,390],[634,540],[339,528]]},{"confidence":0.8131805658340454,"text":"最终相遇","text_region":[[356,532],[624,530],[624,596],[356,598]]}]],"status":"0"}
|
||||||
|
```
|
|
@ -0,0 +1,32 @@
|
||||||
|
# Version: 1.0.0
|
||||||
|
FROM hub.baidubce.com/paddlepaddle/paddle:latest-gpu-cuda10.0-cudnn7-dev
|
||||||
|
|
||||||
|
# PaddleOCR base on Python3.7
|
||||||
|
RUN pip3.7 install --upgrade pip -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN python3.7 -m pip install paddlepaddle==2.0.0rc0 -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN pip3.7 install paddlehub --upgrade -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN git clone https://github.com/PaddlePaddle/PaddleOCR.git /PaddleOCR
|
||||||
|
|
||||||
|
WORKDIR /PaddleOCR
|
||||||
|
|
||||||
|
RUN pip3.7 install -r requirements.txt -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN mkdir -p /PaddleOCR/inference/
|
||||||
|
# Download orc detect model(light version). if you want to change normal version, you can change ch_ppocr_mobile_v1.1_det_infer to ch_ppocr_server_v1.1_det_infer, also remember change det_model_dir in deploy/hubserving/ocr_system/params.py)
|
||||||
|
ADD {link} /PaddleOCR/inference/
|
||||||
|
RUN tar xf /PaddleOCR/inference/{file} -C /PaddleOCR/inference/
|
||||||
|
|
||||||
|
# Download direction classifier(light version). If you want to change normal version, you can change ch_ppocr_mobile_v1.1_cls_infer to ch_ppocr_mobile_v1.1_cls_infer, also remember change cls_model_dir in deploy/hubserving/ocr_system/params.py)
|
||||||
|
ADD {link} /PaddleOCR/inference/
|
||||||
|
RUN tar xf /PaddleOCR/inference/{file}.tar -C /PaddleOCR/inference/
|
||||||
|
|
||||||
|
# Download orc recognition model(light version). If you want to change normal version, you can change ch_ppocr_mobile_v1.1_rec_infer to ch_ppocr_server_v1.1_rec_infer, also remember change rec_model_dir in deploy/hubserving/ocr_system/params.py)
|
||||||
|
ADD {link} /PaddleOCR/inference/
|
||||||
|
RUN tar xf /PaddleOCR/inference/{file}.tar -C /PaddleOCR/inference/
|
||||||
|
|
||||||
|
EXPOSE 8868
|
||||||
|
|
||||||
|
CMD ["/bin/bash","-c","hub install deploy/hubserving/ocr_system/ && hub serving start -m ocr_system"]
|
|
@ -0,0 +1,32 @@
|
||||||
|
# Version: 1.0.0
|
||||||
|
FROM hub.baidubce.com/paddlepaddle/paddle:latest-gpu-cuda10.0-cudnn7-dev
|
||||||
|
|
||||||
|
# PaddleOCR base on Python3.7
|
||||||
|
RUN pip3.7 install --upgrade pip -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN python3.7 -m pip install paddlepaddle-gpu==2.0.0rc0 -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN pip3.7 install paddlehub --upgrade -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN git clone https://github.com/PaddlePaddle/PaddleOCR.git /PaddleOCR
|
||||||
|
|
||||||
|
WORKDIR /PaddleOCR
|
||||||
|
|
||||||
|
RUN pip3.7 install -r requirements.txt -i https://mirror.baidu.com/pypi/simple
|
||||||
|
|
||||||
|
RUN mkdir -p /PaddleOCR/inference/
|
||||||
|
# Download orc detect model(light version). if you want to change normal version, you can change ch_ppocr_mobile_v1.1_det_infer to ch_ppocr_server_v1.1_det_infer, also remember change det_model_dir in deploy/hubserving/ocr_system/params.py)
|
||||||
|
ADD {link} /PaddleOCR/inference/
|
||||||
|
RUN tar xf /PaddleOCR/inference/{file}.tar -C /PaddleOCR/inference/
|
||||||
|
|
||||||
|
# Download direction classifier(light version). If you want to change normal version, you can change ch_ppocr_mobile_v1.1_cls_infer to ch_ppocr_mobile_v1.1_cls_infer, also remember change cls_model_dir in deploy/hubserving/ocr_system/params.py)
|
||||||
|
ADD {link} /PaddleOCR/inference/
|
||||||
|
RUN tar xf /PaddleOCR/inference/{file} -C /PaddleOCR/inference/
|
||||||
|
|
||||||
|
# Download orc recognition model(light version). If you want to change normal version, you can change ch_ppocr_mobile_v1.1_rec_infer to ch_ppocr_server_v1.1_rec_infer, also remember change rec_model_dir in deploy/hubserving/ocr_system/params.py)
|
||||||
|
ADD {link} /PaddleOCR/inference/
|
||||||
|
RUN tar xf /PaddleOCR/inference/{file}.tar -C /PaddleOCR/inference/
|
||||||
|
|
||||||
|
EXPOSE 8868
|
||||||
|
|
||||||
|
CMD ["/bin/bash","-c","hub install deploy/hubserving/ocr_system/ && hub serving start -m ocr_system"]
|
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue