本文介绍: 将迁移脚本应用到数据库中 flask db upgrade 这个执行前确保,alembic_version的标号是最新的,不是手动更新在migrations->versions目录下。#安装flask–sqlalchey flask–migrate mysql数据库。:最后,你需要重启Nginx以应用新的配置。:在Nginx的配置文件中添加一个新的server块。首先拉取mysql的镜像,这里用的mysql5.7.6。目录下的所有文件复制到Nginx的web目录下,例如。目录,里面包含构建后的静态文件。
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
构建:
#基本项目创建 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
启动redis celery -A auto.celery worker -l info -P eventlet
pip3.9 install wechatpayv3==1.2.35 -i https://pypi.tuna.tsinghua.edu.cn/simple/
—link redis:redis–server flask容器就可以读取redis容器redis服务了:
docker run --name redis -d redis:5.0.3 redis-server --appendonly yes
说明:
- 使用Docker运行一个名为”redis“的容器。
- 使用“redis:5.0.3″这个Docker镜像来创建这个容器。这个镜像是Redis数据库的一个版本。
- “-d”参数表示容器将在”detached”模式下运行,也就是说这个容器将在后台运行。
- “redis-server —appendonly yes“是传递给容器的命令,它将启动一个Redis服务器并开启append–only模式。这个模式会把所有的修改操作都记录下来,以便在数据库重启后可以通过这些记录恢复数据。
docker run --name flask -p 5000:5000 -p 3000:3000 --link redis:redis-server -itd auto_flask_nginx_v1.0:v1.0
说明:
- 使用 Docker 运行一个名为 “flask” 的容器。
- 使用 “auto_flask_nginx_v1.0:v1.0″ 这个 Docker 镜像来创建这个容器。
- “-p 5000:5000” 和 “-p 3000:3000” 参数将容器内的端口 5000 和 3000 分别映射到主机的端口 5000 和 3000,这样你就可以通过主机的这两个端口来访问容器内的服务了。
- “–link redis:redis-server” 参数将链接名为 “redis” 的容器到 “flask” 容器,并在 “flask” 容器中用 “redis-server” 这个名字来引用 “redis” 容器。这样,”flask” 容器就可以通过 “redis-server” 这个名字来访问 “redis” 容器提供的服务了。
- “-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]
#项目目录
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
启动:
停止:
uwsgi —stop uwsgi_log/uwsgi.pid
-
部署到Nginx:将
dist
目录下的所有文件复制到Nginx的web目录下,例如/usr/share/nginx/html/
。 -
配置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端口 } }
-
重启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进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。