深度学习模型部署——Flask框架轻量级部署+阿里云服务器

服务器 0

项目场景:

​因为参加一个比赛,需要把训练好的深度学习模型部署到web端,第一次做,在网上也搜索了很多教程,基本上没有适合自己的,只有一个b站up主讲的还不错https://www.bilibili.com/video/BV1Qv41117SR/?spm_id_from=333.999.0.0&vd_source=6ca6a313467efae52a28428a64104c10https://www.bilibili.com/video/BV1Qv41117SR/?spm_id_from=333.999.0.0&vd_source=6ca6a313467efae52a28428a64104c10在前端的一部分html语言借鉴了这个up主,有兴趣的可以去看看。在部署的时候遇到了很多坑,就想记录一下,仅代表个人看法

项目场景:角膜疾病图片识别算法(pytorch环境),用Flask轻量级框架部署到web端并部署到阿里云服务器进行测试。


流程:

1.写预测函数

1.1将训练好的模型参数加载到模型中去

checkpoint_path = "/model_best.pth.tar"   #训练好的模型参数(要注意保存模型的时候是保存了模型还是模型参数,这里是模型参数)model = res50Encoder(attention_map_num, class_num)   #加载模型model.load_state_dict(torch.load(checkpoint_path,map_location='cpu')['state_dict'])#(将参数加载到模型中去)model.eval() #pytorch框架会自动把BN和Dropout固定住,直接用训练好的值

1.2 数据预处理模块

data_transform = transforms.Compose([        transforms.Resize((n, m)),        transforms.CenterCrop(num),        transforms.ToTensor(),        transforms.Normalize(a,b),    ])        #根据自己的模型,写出数据预处理模块,n,m,num,a,b按照自己的模型填写

1.3 加载数据(我是图片的二进制格式)

img = Image.open(io.BytesIO(image_bytes)) #将图片的二进制文件转化img = data_transform(img) #数据变换img = img.float().unsqueeze(0) #数据调整维度

 1.4 数据标签,根据自己的模型数据集的标签定义

class_labels=['','','']  #自己往''填label

1.5 开始预测

 with torch.no_grad():        attention_maps, _, output1, coarse_logits= model(img.cpu())        refined_input = mask2bbox(attention_maps, img.cpu())        _, _, output2, _= model(refined_input)        output = (output1 + output2) / 2        output = torch.softmax(output, dim=-1)#根据output输出标签值 _, pred = torch.max(output, 1)    pred_label = class_labels[pred.item()]

2. 利用Flask框架部署

直接看代码吧,这是app.py 

#app.pyfrom flask import Flask, jsonify, requestfrom yuce import predfrom flask_cors import CORSimport flaskapp = Flask(__name__)CORS(app)  #跨域问题@app.route('/predict', methods=['POST'])def predict():    if request.method == 'POST':        file = request.files['file']        print(file)        img_bytes = file.read()        class_name = pred(img_bytes)        #预测函数pred()(第一个步骤写的)        if(class_name ):            print("结果:"+class_name)        else:            print("error")        return jsonify({ 'class_name': class_name})    return jsonify({"your call is GET"})   #将化成标签json格式@app.route("/",methods = ['POST','GET'])def root():    return flask.render_template("upload.html")   #前端交互界面if __name__ == '__main__':    app.run(host="0.0.0.0",port=80,debug=True)    

3.写前端交互界面upload.html(借鉴b站up主,前面有提到) 

可自行去up主的GitHub下载https://github.com/WZMIAOMIAO/deep-learning-for-image-processing/tree/master/deploying_service/deploying_pytorchhttps://github.com/WZMIAOMIAO/deep-learning-for-image-processing/tree/master/deploying_service/deploying_pytorch

4.在本地成功跑起来后,可以得到这样一个界面 

 然后就可以自行上传图片进行预测

5.阿里云服务器部署

5.1首先要准备一个阿里云服务器,新人有一个月的优惠,但是只能租用cpu,所以如果你的模型是gpu请自行购买gpu服务器,当然你也可以改变你的模型,用cpu跑(因为穷,所以我就把模型改成cpu跑,从第一步的代码可以看出,当然要小心输入要一致,也要用.cpu)。然后我选择的是ubuntu系统

5.2准备好xshell7和xftp7两个软件,xshelll7是可以登录你的ssh,然后用来跑代码。xftp7是上传文件,可以从本地把文件传到服务器上去。

xshell7登录:

 将自己的ssh填上去,然后用户身份验证进行登录。

 xftp7登录:和上图差不多

 然后就可以在服务器上跑代码,但是要注意安装相对应的库,需要小心代码中的路径问题,当服务器上面成功跑起来,就可以用公网IP访。(再将公网IP部署到你的域名,就可以访问网址,注意备案!!,不然会被封号)

问题描述+解决问题

部署过程中遇到很多困难

1.注意安装jQuery库,可以去up主的github上直接下载,注意安装到static库下面

2.注意你买的服务器类型,如果是cpu要修改输入!!!

#(将参数加载到模型中去)model.load_state_dict(torch.load(checkpoint_path,map_location='cpu')['state_dict'])#注意img.cpu()attention_maps, _, output1, coarse_logits= model(img.cpu())refined_input = mask2bbox(attention_maps, img.cpu())

 3.部署到服务器上去可能会遇到无法响应的情况,可能是端口没有开启,可以去阿里云的网络安全组开启端口,我的端口是80,可以在下图中自己手动修改!!开启后,打开要用公网ip!!!

 

 如果还是无法访问可以自行查看阿里云的帮助ECS实例的安全组规则未生效_云服务器 ECS-阿里云帮助中心

 小结:

第一次自己部署深度模型,经验不足,仅供参考。

也许您对下面的内容还感兴趣: