首先拉取mysql镜像这里用的mysql5.7.6

docker pull mysql:5.7.6

镜像拉取完成后启动

docker run --name my-mysql -d -p 3306:3306 -v /usr/local/my-mysql/conf:/etc/mysql/conf.d -v /usr/local/my-mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456  mysql:5.7.6

利用dockerfile构建python3.9.11+uwsgi+nginx

FROM python:3.9.11

# 为镜像添加标签
LABEL version="v1" description="Docker deploy Flask" by="guochunbiao"
RUN mkdir /opt/flask_app
COPY ./bask_flask /opt/flask_app/bask_flask
COPY ./dist /opt/flask_app/dist
COPY ./site-pages /usr/local/lib/python3.9/site-packages
COPY ./nginx.conf /etc/nginx/nginx.conf
# 配置工作目录
WORKDIR /opt/flask_app

# 在镜像容器中执行命令
RUN pip install Flask && pip install uwsgi -i https://pypi.tuna.tsinghua.edu.cn/simple/
#RUN pip install Flask && pip install -r request.txt -i https://pypi.tuna.tsinghua.edu.cn/simple/

#安装nginx
apt-get update
apt-get install nginx
apt-get install vim

构建

docker build -t mydemo .

flask配置

#基本项目创建
pip freeze > requirements.txt

安装pip install -r requirements.txt

#安装flask-sqlalchey flask-migrate mysql数据库
pip install flask-sqlalchemy flask-migrate
#安装 flask-cors解决跨域访问
pip install flask-cors

数据库迁移
      创建迁移数据库 flask db init
      生成迁移脚本 flask db migrate -m "add user tables"
      将迁移脚本应用到数据库中 flask db upgrade 这个执行前确保,alembic_version标号最新的,不是手动更新在migrations->versions目录下
      将迁移脚本回滚 flask db downgrade

celery:

启动redis celery -A auto.celery worker -l info -P eventlet

微信支付python的库

pip3.9 install wechatpayv3==1.2.35 -i https://pypi.tuna.tsinghua.edu.cn/simple/

link redis:redisserver flask容器可以读取redis容器redis服务了:

docker pull redis:5.0.3

docker run --name redis -d redis:5.0.3 redis-server --appendonly yes

说明

  1. 使用Docker运行一个名为”redis“的容器。
  2. 使用redis:5.0.3″这个Docker镜像来创建这个容器。这个镜像是Redis数据库的一个版本
  3. “-d”参数表示容器将在”detached”模式运行,也就是说这个容器将在后台运行。
  4. redis-server —appendonly yes“是传递给容器的命令,它将启动一个Redis服务器开启appendonly模式。这个模式会把所有的修改操作记录下来,以便数据库重启可以通过这些记录恢复数据
docker run --name flask -p 5000:5000 -p 3000:3000  --link redis:redis-server -itd auto_flask_nginx_v1.0:v1.0

说明

  1. 使用 Docker 运行一个名为 “flask” 的容器。
  2. 使用auto_flask_nginx_v1.0:v1.0″ 这个 Docker 镜像来创建这个容器。
  3. “-p 5000:5000” 和 “-p 3000:3000” 参数将容器内的端口 5000 和 3000 分别映射主机端口 5000 和 3000,这样你就可以通过主机的这两个端口访问容器内的服务了。
  4. “–link redis:redis-server” 参数链接名为 “redis” 的容器到 “flask” 容器,并在 “flask” 容器中用 “redis-server” 这个名字引用redis” 容器。这样,”flask” 容器就可以通过redis-server” 这个名字访问redis” 容器提供的服务了。
  5. “-itd参数表示容器将在 “detached” 模式下运行,并以交互模式打开一个伪终端
# 获取access_token用来获取微信用户openid
def secret_token(code, user):
    redis_conn = redis.Redis(host='redis-server', port=6379)
    is_key = redis_conn.hget('{}_zc_token'.format(user), 'wx_token')
    if is_key:
        return is_key
    else:
        url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid={0}&secret={1}&code={2}&grant_type=authorization_code".format(
            APP_ID,
            APP_SECRET, code)
        response_data = requests.get(url)
        eval_resp = eval(response_data.content)
        redis_conn.hset('{}_zc_token'.format(eval_resp.get('openid')), 'wx_token', response_data.content)
        redis_conn.expire('{}_zc_token'.format(eval_resp.get('openid')), 7100)
        return response_data.content

参考连接

http://hk.javashuo.com/article/p-kgdqsqip-bv.html

uwsgi.ini配置

[uwsgi]
#项目目录
chdir=/opt/flask_app
#指定项目应用固定写法,承接上面的项目目录
module=auto:app
wsgi-file=/opt/flask_app/auto.py
callable=app
#sock文件存放目录,方便nginx进行sock连接交互
socket=/opt/flask_app/uwsgi_log/uwsgi.sock
#并发进程
workers=5
#进程id存放文件
pidfile=/opt/flask_app/uwsgi_log/uwsgi.pid
#启动ip端口
http=0.0.0.0:5000
# 对应app.py文件中Flask对象对应变量名
callable=auto
#静态文件映射第一个等于代表Django里面别名第二个等于后面是Django里面的真实路径
#static-map=/static=/opt/AutomationPlatform/frontend/static/
#启动用户和组
uid=root
gid=root
#启用主进程
master=true
#自动移除unixSocket和pid文件当服务停止的时候
vacuum=true
#序列化接受的内容,如果可能的话
thunder-lock=true
#启用线程
enable-threads=true
#设置中断时间
harakiri=36000
#设置缓存
post-buffering=1024
#日志存放目录,方便拍错
daemonize=/opt/flask_app/uwsgi_log/uwsgi.log

启动:

uwsgiini uwsgi.ini

停止:

uwsgistop uwsgi_log/uwsgi.pid

部署Vue3到Nginx设置请求转发需要以下步骤:

  1. 构建Vue3项目:在项目目录下运行npm run build命令。这会生成一个dist目录,里面包含构建后的静态文件。

  2. 部署到Nginx:将dist目录下的所有文件复制到Nginxweb目录下,例如/usr/share/nginx/html/

  3. 配置Nginx转发请求:在Nginx配置文件添加一个新的server块。例如

    server {
      listen 80;
      server_name yourdomain.com;
      location / {
        root /usr/share/nginx/html; # Vue3项目在Nginx路径
        index index.html;
        try_files $uri $uri/ /index.html; # 用于支持Vue的history模式
      }
      location /api {
        proxy_pass http://backend:3000; # 假设后端服务运行在3000端口
      }
    }
    

  4. /api路径下的所有请求都会被转发到后端服务

  5. 重启Nginx最后,你需要重启Nginx以应用新的配置。在Linux上,你可以使用sudo systemctl restart nginx命令。

原文地址:https://blog.csdn.net/guochunbiao0416/article/details/133296396

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_21094.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注