预先训练深度学习模型,保存训练后的模型或参数,此处采用图像分类模型。
Flask是一个使用 Python 编写的轻量级Web应用框架,可通过$pip install flask
进行安装。
首先编写app.py文件
import os
from flask import Flask, render_template, request, redirect
import io
from PIL import Image
import uuid
import vision
app = Flask(__name__)
CURRENT_DIR = os.path.dirname(os.path.abspath(__file__))
CACHE_FOLDER = os.path.join(CURRENT_DIR, 'static/')
@app.route('/', methods=['GET', 'POST'])
def upload_file():
if request.method == 'POST':
if 'file' not in request.files:
return redirect(request.url)
file = request.files.get('file')
if not file:
return
# 读取上传的图像
img_bytes = file.read()
image = Image.open(io.BytesIO(img_bytes))
# 获得分类结果
image_result, class_name, class_id = vision.classify_image(image)
# 将图像保存于本地
img_stream = str(uuid.uuid1()) + ".jpg"
cache_name = CACHE_FOLDER + "/" + img_stream
image_result.savefig(cache_name, dpi=300, bbox_inches='tight')
# 传递至模板
return render_template('result.html',
class_id=class_id,
class_name=class_name,
img_name='结果图像保存于/static/' + img_stream)
return render_template('index.html')
if __name__ == '__main__':
# 地址需要是0.0.0.0,保证外机访问
app.run(host="0.0.0.0", debug=True, port=5000)
Docker 是一个开源的应用容器引擎,基于Go语言并遵从 Apache2.0 协议开源。 Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。 容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app), 更重要的是容器性能开销极低。
安装Docker Desktop:https://hub.docker.com/editions/community/docker-ce-desktop-windows/
修改下载默认源
右键桌面右下角Docker Desktop图标,选择setting - Docker Engine,修改"registry-mirrors": [ "http://hub-mirror.c.163.com" ]
,改为163源。
修改镜像存放目录
默认镜像存放目录有足够容量可以跳过此步
首先查看setting - Docker Engine - Resources - Disk image location找到默认镜像存放目录,例如:C:\ProgramData\DockerDesktop\vm-data
。将文件夹vm-data剪切到想要改变的目标镜像存放目录,例如:D:\vm-data
。
以管理员身份运行cmd,输入$mklink /J "C:\ProgramData\DockerDesktop\vm-data" D:\vm-data
,创建符号链接。
首先新建一个名为docker_test的文件夹,内部结构如下
docker_test
----flask_app // flask项目文件夹
--------app.py // flask加载文件
--------(其他项目内文件,包括模型文件)
--------requirement.txt
----Dockerfile
----sources.list
下面介绍各个文件的生成
$pip install pipreqs
$pipreqs . --encoding=utf8 --force
,–force表示覆盖原requirement.txt。源列表,用于替换Ubuntu的默认源
deb-src http://archive.ubuntu.com/ubuntu xenial main restricted #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial main restricted
deb-src http://mirrors.aliyun.com/ubuntu/ xenial main restricted multiverse universe #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted multiverse universe #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial universe
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates universe
deb http://mirrors.aliyun.com/ubuntu/ xenial multiverse
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates multiverse
deb http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse #Added by software-properties
deb http://archive.canonical.com/ubuntu xenial partner
deb-src http://archive.canonical.com/ubuntu xenial partner
deb http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted multiverse universe #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial-security universe
deb http://mirrors.aliyun.com/ubuntu/ xenial-security multiverse
Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。
基础镜像
可以在https://hub.docker.com/search?type=image上搜索想要的基础镜像文件,点击镜像页面上的Tags复制镜像下载命令,此处选择带有pytorch和ubuntu环境的镜像:
在命令行执行$docker pull macio232/torch1.4.0-ubuntu18.04-extras:latest-nocuda
下载基础镜像。
编写Dockerfile
# 基于的基础镜像
FROM macio232/torch1.4.0-ubuntu18.04-extras:latest-nocuda
# 维护者信息
MAINTAINER name [email protected]
#用ubuntu国内源替换默认源
RUN rm /etc/apt/sources.list
COPY sources.list /etc/apt/sources.list
# 代码添加到 code 文件夹
ADD ./flask_api_test /code
# 设置 code 文件夹是工作目录
WORKDIR /code
# 更新软件包列表
RUN apt-get update
# 此处为cv2相关支持,无cv2可删去
RUN apt-get install -y libsm6 libxext6 libgl1-mesa-glx libglib2.0-0
# 安装相关支持
RUN pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple
# 声明镜像内服务监听的端口
EXPOSE 5000
CMD ["python", "/code/app.py"]
在docker_test文件下执行$docker build -t user_name/image_name:tag .
,在用户user_name下生成名为image_name、标签为tag的镜像。
$docker run -i -p 5000:5000 user_name/image_name:tag
* Serving Flask app "app" (lazy loading)
* Environment: production
WARNING: This is a development server. Do not use it in a production deployment.
Use a production WSGI server instead.
* Debug mode: on
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
* Restarting with stat
* Debugger is active!
-i表示以交互模式运行容器,-p表示指定端口映射,接着即可在网址中输入localhost:5000
访问。
右键桌面右下角Docker Desktop图标,选择setting - Docker Engine,修改"insecure-registries": [ "user_name" ]
执行$docker push user_name/image_name:tag
上传至user_name源
私有仓库的构建见:https://www.linuxidc.com/Linux/2018-03/151308.htm
$docker login
登陆$docker push user_name/image_name:tag
上传在网上找了很多IDEA启动没反应的解决方法,但是我的状况跟其对应的出错情况不相符,后来自己解决了。这里只是提供一个可能的解决方法:安装路径修改成全英文的,不要出现中文。可能会有人使用的是中文路径,可以尝试一下。...
1.html代码<div class="box"> <!--滑块--> <a href="#"><div class="btn">>></div></a> <!--文字--> <p class="text">拖动滑块验证</p> <!--背景...
一、跳石板1.描述【解题思路】:平均分三份是最快的方法,两份进行称重(对比出三个的重量),后对最重的那份再次进行称重,直到称重的个数不足2个时则结束,获得假币如果无法平均分3分则余数要么是1要么是2,因为是要最多称几次,n=n/3+1满足每次取最大分称3份,取两份一样多的过秤,然后把三份中最多的那份继续分,直到硬币剩余0或1时截止。2.代码实现#include<iostream>using namespace std;int main(){ int n=0;
问题描述通过pickle读取/保存.pkl文件实现方法读取import picklewith open('a.pkl', 'rb') as f: a = pickle.load(f)保存import picklea = [1, 2, 3]with open('a.pkl', 'wb') as f: pickle.dump(a, f)问题解决
PXE配合Kickstart无人值守装机一、PXE概述二、PXE批量部署的优点三、部署PXE远程安装服务四、搭建PXE远程安装服务器1.安装并启用TFTP 服务2.安装并启用DHCP服务3.准备Linux 内核、初始化镜像文件4.准备PXE引导程序5.安装FTP服务,准备CentOS 7 安装源6.配置启动菜单文件验证PXE网络安全五、实现Kickstart无人值守安装(桌面环境)(1)、安装system- config- kickstart 工具(2)、打开“Kickstart 配置程序”窗口(3)、配置
首先在AndroidStudio中将数据转换为yuv图片数据,然后传到Unity,Unity解析Yuv图片数据并显示MediaCodec mCodec = MediaCodec.createDecoderByType("video/avc");final MediaFormat mediaformat = MediaFormat.createVideoFormat("video/avc",...
http://homepages.inf.ed.ac.uk/rbf/HIPR2/label.htmConnected Components LabelingCommon Names: Connected Components LabelingBrief DescriptionConnected components labeling scans an i
目录文档用途详细信息文档用途本文档主要用于指导瀚高数据库使用人员在线重建索引。详细信息情景一:单个索引/少量索引重建查询某个表对应的索引信息:highgo=# select * from pg_indexes where tablename = 'test01'; schemaname | tablename | indexname | tablespace | indexdef
Darknet源码——image结构体darknet内部的image结构体定义image结构体定义在image.h,定义如下:typedef struct { int h; int w; int c; float *data;} image;从以上定义中可以看出,darknet内部使用一维数组存放图像像素数据。与OpenC...
今天通过一份销售数据,聊聊Power BI数据分析。一、分析数据数据源总的有四个表,店铺资料,销售目标,销售数据_本期,销售数据_去年同期。各表表头如下:1店铺资料表:2销售目标:3销售数据_本期:4销售数据_去年同期:数据中包含多个城市、督导、店铺的数据,我希望经过分析后能得到各个城市/店铺的销售情况,即业绩、业绩完成率、业绩贡献度、业绩增长率、各销售人员的销售能力等。此次...
给定a、b两个文件,各存放50亿个url,每个url各占64字节,内存限制是4G,让你找出a、b文件共同的url?两种方法:一、采用Bloom filter,假设布隆过滤器的错误率为0.01,则位数组大小m约为输入元素个数n的13倍,此时需要的哈希函数k约为8个。元素个数:n = 5G位数组大小:m = 5G * 13 = 65G = 650亿 即需要650亿个bit位才能达到错误...
ps: 如果有任何问题可以评论留言,我看到后会及时解答,评论或关注,您的鼓励是我分享的最大动力 转载请注明出处:https://blog.csdn.net/qq_40938301/article/details/89303891问题原因:没有配置环境变量或者环境变量没有配置好解决方法:找到 /etc/profile 这个文件 vi / vim / gedit...