利用docker 开发 信息系统,python + mysql + flask + jquery

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 利用docker 开发 信息系统,python + mysql + flask + jquery

源码下载,以及项目部署方法

源码下载地址 阿里效云 https://code.aliyun.com/734449600/dockerDeploryFlaskMysql/repository/archive.zip?ref=master

部署命令

解压mysqldata.zip 确定 文件夹中的 mysqldata的绝对路径
里边存放的 mysql 数据库结构以及配置文件
# 创建网路
docker network create --driver bridge --subnet 10.10.0.0/16  --gateway 10.10.0.1 mynet1
# 创建数据库  
#注意把 C:/Users/73444/Desktop/mysqldata/data  换成 mysqldata 的绝对路径
docker run -di --name mysql1 -p 33306:3306 --net mynet1 --ip 10.10.10.11 -v C:/Users/73444/Desktop/mysqldata/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=lmk19980312 registry.cn-hangzhou.aliyuncs.com/mkmk/mysql:8-0-19
# 创建 flask 项目
docker run -di -p 35000:5000  --name flask_demo_cn  --net mynet1 --ip 10.10.10.12 registry.cn-hangzhou.aliyuncs.com/mkmk/flask:studentTemperature

写作目的

python 课程又留了一个增删改查系统,不写吧又不行,重复工作吧又没有意义,然后就针对想要学习迅捷开发部署的 同学写个小教程

  1. 现在各种软件实在太多了,全部下载安装到电脑,简直不堪重负,
  2. 每款软件 配置都很繁琐,
  3. 项目复现困难, 做过的东西,用一次,下次又找不到了
  4. 便于服务迁移与部署升级

所以我们要学习迅捷开发部署,并且上传云端保存环境,直接复现查看效果


本次我们由于面向教学,大家很多没有linux 系统,所以直接在 win10 环境下进行教学

这次就做个简单的学生疫情统计网页吧。

安装docker

阿里 效云 下载

https://code.aliyun.com/734449600/DockerDesktopInstaller/raw/master/Docker%20Desktop%20Installer.exe

直接去官网下载也可以


网络环境搭建

我们本次只有两个网络节点, 一个 mysql节点, 一个 flask 节点

设计ip分配

mysql 10.10.10.11 3306 宿主机访问端口 33306

flask 10.10.10.12 5000 宿主机访问端口 35000


创建网络

docker network create --driver bridge --subnet 10.10.0.0/16  --gateway 10.10.0.1 mynet1

数据库搭建

创建mysql 容器环境

#从一开始就要挂在目录,当容器已经运行,再拷贝目录出来是会报错的
# 请先在本地创建持久化数据的文件夹 C:/Users/73444/Desktop/mysqldata/data
# 创建容器
docker run -di --name mysql1 --net mynet1 --ip 10.10.10.11  -p 33306:3306 -v C:/Users/73444/Desktop/mysqldata/data:/var/lib/mysql     -e MYSQL_ROOT_PASSWORD=lmk19980312 registry.cn-hangzhou.aliyuncs.com/mkmk/mysql:8-0-19
# 进入容器
docker exec -it  mysql1 /bin/bash 
查看mysql 版本 ,大写 -V
mysql -V
mysql  Ver 8.0.19 for Linux on x86_64 (MySQL Community Server - GPL)
登录mysql
mysql -u root -p
默认密码 lmk19980312
mysql>
授权远程登陆
mysql>  GRANT ALL ON *.* TO 'root'@'%';
flush privileges;
更改加密规则
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;
  
更新root用户密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'lmk19980312';
刷新权限
flush privileges;

navicate 连接, 注意,我们由于采用了端口映射

mysql 端口在 33306 -p 33306:3306

20200308125941775.png

创建 database ,table

不再复述网上教程很多,直接上结果20200308130825147.png


简单说明

id 是主键,自增

time 设成时间戳比较麻烦,我准备直接在python 中生成格式时间

stuno 学号

stuname 姓名

temperature 体温


python-flask后台开发

接口简述

insertRecord 插入记录
delById 删除记录通过id
getAllRecord 查看所有记录
getAbnRecorde 查看不正常记录


结合业务需要,不能随意修改记录,

源代码已经上传至 阿里巴巴 效云

文件目录


jquery 结合 jinja2 前端页面开发

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="{{ url_for('static',filename='jquery-3.4.1/jquery-3.4.1.js') }}" ></script>
</head>
<style>
    body{ text-align:center;text-va}
    #divjuzhong{margin:0 auto;border:1px solid #000;width:300px;height:100px}
    .fa1{display: flex; justify-content: center; align-items: center;min-width: 1600px;min-height: 500px;}
    .fa2{min-width: 1400px; min-height: 300px; background-color: blanchedalmond;}
    .del1{}
</style>
<script type="text/javascript">
$(document).ready(function(){
  $("#click1").click(function(){
      if (  $('#input1').val().length<5 || $('#input2').val().length<2 || $('#input3').val().length != 4    )
      {
          alert("请检查你的输入");
          return
      }
      $.get("/insertRecord",{ stuNo: $('#input1').val() ,
                                stuName: $('#input2').val(),
                                temperature: $('#input3').val()},
            function (data) {
                 alert("提交成功");
                 location.assign("/")
            });
  });
});
  function del1(id1){
      $.get("/delById", {
        id: id1
      },
            function (data) {
                 alert("删除成功" );
                 location.assign("/")
            });
  };
    function getAbn(){
      $.get("/delById",
            function (data) {
                 location.assign("/getAbnRecorde")
            });
  };
    function  getall(){
      $.get("/delById",
            function (data) {
                 location.assign("/")
            });
  };
</script>
<body>
<div class="fa1" >
    <div class="fa2">
        <table border="1" style="background-color: aliceblue">
            <tr>
                <td onclick="getall()">查看所有记录</td>
                <td style="width: 20px"> </td>
                <td onclick="getAbn()">查看异常记录</td>
            </tr>
        </table>
        <table border="2" class="fa2">
        <caption>学生体温统计表</caption>
            {# 表头        #}
            <tr style="font-size: larger">
                    {% for item in heads %}
                        <td> {{ item }} </td>
                    {% else %}
                        <td> {{ "服务器故障" }} </td>
                    {% endfor %}
            </tr>
            <tr>
                <td></td><td></td>
                <td><input id="input1" type="text" size="15" min-length="30" placeholder="请输入 学号 大于五位"></td>
                <td><input id="input2" type="text" size="15" min-length="30" placeholder="请输入 姓名 大于两个字"></td>
                <td><input id="input3" type="text" size="15" min-length="30" placeholder="请输入 真实体温 例如 36.5"></td>
                <td id="click1" style="background-color: azure"  > 提交 </td>
            </tr>
            {% for oneinfo in allinfo %}
                <tr style="font-size: medium">
                <script language="JavaScript"> var id1=0 </script>
                    {% for onestr in oneinfo %}
                        <script language="JavaScript">
                            if (id1==0){id1='{{ onestr }}' }
                        </script>
                        <td> {{ onestr }} </td>
                    {% else %}
                        <td> {{ "服务器故障" }} </td>
                    {% endfor %}
                    <td  onclick="del1(id1)"  style="background-color: azure"  > {{ "删除" }} </td>
                </tr>
            {% else %}
                    <td> {{ "服务器故障" }} </td>
            {% endfor %}
        </table>
    </div>
</div>
</body>
</html>

封装flask容器步骤

创建文件夹 flask_docker 名称随意



其中flask_demo 放置源代码

书写Dockerfile

#基于的基础镜像
FROM python:3
#代码添加到code文件夹
ADD ./flask_demo  /usr/src/app
# 设置app文件夹是工作目录
WORKDIR /usr/src/app
# 安装支持
RUN pip install Flask==1.1.1 Jinja2==2.11.1 PyMySQL==0.9.3 cryptography -i  https://pypi.tuna.tsinghua.edu.cn/simple
CMD [ "python", "/usr/src/app/app.py" ]


创建镜像 命令最后的 点 . 不要省略
docker build -t  registry.cn-hangzhou.aliyuncs.com/mkmk/flask:studentTemperature   .
使用镜像
docker run -it -p 35000:5000  --name flask_demo_cn  --net mynet1 --ip 10.10.10.12  registry.cn-hangzhou.aliyuncs.com/mkmk/flask:studentTemperature

此时访问 localhost:35000 即可 看到网页

完成

docker常用命令

#强制删除所有镜像和容器
docker stop -f  $(docker ps -a -q) | docker rm -f $(docker ps -a -q) |  docker rmi -f $(docker images -q)
#查看镜像列表
docker images
#删除单个镜像
docker rmi image-id
#删除所有镜像
docker rmi $(docker images -q)
#查看运行中的容器
docker ps
#查看所有容器
docker ps -a
#停止单个容器
docker stop container-id
#停止所有容器
docker stop $(docker ps -a -q)
#删除单个容器
docker rm container-id
#删除所有容器
docker rm $(docker ps -a -q)
#删除系统数据
docker system prune
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
66 44
|
3天前
|
机器学习/深度学习 数据采集 存储
使用Python实现智能农业灌溉系统的深度学习模型
使用Python实现智能农业灌溉系统的深度学习模型
25 6
|
3天前
|
数据可视化 开发者 Python
Python GUI开发:Tkinter与PyQt的实战应用与对比分析
【10月更文挑战第26天】本文介绍了Python中两种常用的GUI工具包——Tkinter和PyQt。Tkinter内置于Python标准库,适合初学者快速上手,提供基本的GUI组件和方法。PyQt基于Qt库,功能强大且灵活,适用于创建复杂的GUI应用程序。通过实战示例和对比分析,帮助开发者选择合适的工具包以满足项目需求。
27 7
|
5天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
探讨了Python开发中性能优化和代码审查的重要性,介绍了选择合适数据结构、使用生成器、避免全局变量等性能优化技巧,以及遵守编码规范、使用静态代码分析工具、编写单元测试等代码审查方法,旨在帮助开发者提升开发效率和代码质量。
24 8
|
1天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
性能优化与代码审查:提升Python开发效率
7 1
|
2天前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
8 1
|
3天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
19 2
|
4天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
10 3
|
4天前
|
JSON API 数据格式
如何使用Python和Flask构建一个简单的RESTful API。Flask是一个轻量级的Web框架
本文介绍了如何使用Python和Flask构建一个简单的RESTful API。Flask是一个轻量级的Web框架,适合小型项目和微服务。文章从环境准备、创建基本Flask应用、定义资源和路由、请求和响应处理、错误处理等方面进行了详细说明,并提供了示例代码。通过这些步骤,读者可以快速上手构建自己的RESTful API。
15 2
|
IDE 开发工具 Android开发
Python开发神器PyCharm,体验下吧
Python开发神器PyCharm,体验下吧
178 0
Python开发神器PyCharm,体验下吧