赞
踩
因为参加一个比赛,需要把训练好的深度学习模型部署到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将训练好的模型参数加载到模型中去
- 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()]
直接看代码吧,这是app.py
- #app.py
-
-
- from flask import Flask, jsonify, request
- from yuce import pred
- from flask_cors import CORS
- import flask
- app = 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)
然后就可以自行上传图片进行预测
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-阿里云帮助中心
第一次自己部署深度模型,经验不足,仅供参考。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。