Flask+Mysql项目docker-compose部署(Python&docker-compose详细步骤)

一、前言

  • 环境:

    Linux、docker、docker-compose、python(Flask)、Mysql

  • 简介:

    简单使用Flask框架写的查询Mysql数据接口,使用docker部署,shell脚本启动

  • 优势:

    采用docker方式部署更加便于维护,更加简单快捷,简单来说:好用

二、项目样式

文件:

Docker运行

flaskweb+mysql

Mysql:

接口样式:

脚本启动:

三、核心点

  1. docker打包python项目:build打包使用Dockerfile文件,这里需要一个python模块requirements.txt文件用于pip安装模块。
    使用docker build -t flaskmysql:v2.0.0进行打包
    flaskweb:
    requirements.txt
  2. docker-compose:使用docker-compose进行打包,使用docker-compose.yml文件,使用docker-compose up -d启动

四、代码

flaskMysql.py

python 复制代码
from flask import Flask,jsonify
import pymysql

app = Flask(__name__)

@app.route('/')
def hello_world():
    conn = pymysql.connect(
    host='192.168.2.136',  # 主机名
    port=13306,         # 端口号,MySQL默认为3306
    user='root',       # 用户名
    password='Dl123456', # 密码
    database='face',   # 数据库名称
    )
    # 创建游标对象
    cursor = conn.cursor()
    # 执行 SQL 查询语句
    cursor.execute("SELECT * FROM base_customers")
    # 获取查询结果
    result = cursor.fetchall()
    return jsonify(result)

if __name__ == '__main__':
    app.config['JSON_AS_ASCII'] = False
    app.run(host='0.0.0.0',port='8085', debug=True)

Dockerfile

python 复制代码
FROM python:3.9
WORKDIR /app/etc
COPY ./requirements.txt /app/etc	
COPY ./flaskMysql.py /app/etc
RUN pip install --no-cache-dir -r /app/etc/requirements.txt 
CMD [ "python", "./flaskMysql.py" ]

requirements.txt

powershell 复制代码
Flask==3.0.0
PyMySQL==1.0.2

docker-compose.yml:

yaml 复制代码
version: '3.1'
services:
  mysql:
    image: mysql:5.7
    container_name: mysql
    restart: always
    network_mode: 'bridge'
    ports:
     - "13306:3306"
    volumes:
     - /opt/python_project/mysql/conf:/etc/mysql/conf
     - /opt/python_project/mysql/data:/var/lib/mysql
     - /opt/python_project/mysql/logs:/logs
    environment:
     MYSQL_ROOT_PASSWORD: Dl123456
  flaskweb:
    image: flaskmysql:v2.0.0
    container_name: flaskweb
    restart: always
    network_mode: 'bridge'
    ports:
     - "8085:8085"                                                                                                                                                                                          

startFlaskweb.sh

powershell 复制代码
#!/bin/bash
flaskcontainerId=`docker ps -a | grep flaskweb | awk '{print $1}'`
flaskcontainerName=`docker ps -a | grep flaskweb | awk '{print $2}'`
mysqlcontainerId=`docker ps -a | grep mysql:5.7 | awk '{print $1}'`
mysqlcontainerName=`docker ps -a | grep mysql:5.7 | awk '{print $2}'`

if [[ $flaskcontainerId || $mysqlcontainerId ]];then
    docker stop ${flaskcontainerId}
    docker stop ${mysqlcontainerId}
    docker rm ${flaskcontainerId}
    docker rm ${mysqlcontainerId}
    echo "delete ${flaskcontainerName} --SUCCESS"
    echo "delete ${mysqlcontainerName} --SUCCESS"
fi

docker-compose up -d

五、总结

简单搭建了一个flask接口项目,使用docker进行部署,用来练习docker-compose部署与docker打包,docker-compose.yml文件格式很严格,每个:后面都要跟一个空格,Dockerfile文件大致是引入程序运行环境,比如python、openjdk等,需要copy那些文件进入容器里面,确定工作路径,需要运行那些命令作为程序启动前的操作,最后CMD运行那个命令来启动项目,你可以写个shell脚本copy进入容器里面用来启动项目。

相关推荐
黄粱梦醒32 分钟前
UV快速搭建新项目
python
江湖有缘33 分钟前
保姆级教程:Docker 部署 Portracker 端口监控工具
jvm·docker·容器
小学生-山海38 分钟前
【YOLO系列】基于YOLOv8/v11/v26与tkinter的车流量统计系统设计
python·yolo
szial1 小时前
Python Click 教程:从函数到专业命令行工具
开发语言·python
u0119608231 小时前
ray 依赖分发
python
努力努力再努力wz1 小时前
【MySQL 进阶系列】C/C++ 如何通过客户端库访问 MySQL?从连接原理到 API 调用流程详解(附完整demo代码)
服务器·c语言·数据结构·数据库·c++·b树·mysql
lbb 小魔仙1 小时前
Ollama 本地部署大模型 + Python API 集成开发完整教程(2026最新版,含 GPU 加速配置)
开发语言·python
DanCheng-studio1 小时前
毕设分享 深度学习遮挡下的人脸识别(源码+论文)
python·毕业设计·毕设
小妖同学学AI1 小时前
告别手动盯盘!开源框架Freqtrade,教你用Python打造“永不下班”的AI交易员
人工智能·python·开源
xxjj998a1 小时前
PHP vs Go vs Python:三大语言终极对比
python·golang·php