Gunicorn多worker跑Flask应用Session数据共享问题

问题描述

使用Gunicorn设置多个worker跑flask应用后发现session状态存在各种紊乱的情况,使用session保存的用户登录状态过一会儿就丢失了,如果直接用python app.py跑的话一点问题也没有,日志中也看不出来有什么错误.

原因分析

Gunicorn中的worker实际上对应的是多进程,默认配置每个worker之间是独立存在的进程,也就是说每个worker会实例化一个新的Flask对象跑起来,这样的话如果代码中使用了随机变量作为sessionSECRET_KEY,那么每个worker都会生成不同的KEY,这样也就无法共享session中存放的键值了.

处理的办法

  1. 使用固定的SECRET_KEY
  2. 将要使用session存放的数据修改成写到数据库中,这样Gunicorn中使用worker实现的多进程之间就不会出现数据不同步的情况了.

参考资料

参考了stackoverflow上面的这个问题的回复:

https://stackoverflow.com/questions/30984622/flask-session-not-persistent-across-requests-in-flask-app-with-gunicorn-on-herok

Looks like there were two problems:

  • The app.secret_key shouldn’t be set to os.urandom(24) because every worker will have another secret key
  • For some reason the dict where I stored my sessions in was sometimes empty and sometimes not… Still haven’t found the reason for this though
    Storing the sessions in a database instead a dictionary at runtime solves the problem.
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 在安装了 GunicornFlask 之后,你可以使用 Gunicorn 来启动 Flask 应用。 示例命令如下: ``` gunicorn --bind 0.0.0.0:8000 --workers 4 myapp:app ``` 其中,`myapp` 是你的 Flask 应用所在的模块,`app` 是你的 Flask 应用实例。 `--bind` 参数用于指定 Gunicorn 应监听的地址和端口。 `--workers` 参数用于指定 Gunicorn 应使用的工作进程数量。 你也可以使用其他的命令行参数来调整 Gunicorn 的行为,例如 `--timeout` 参数用于设置超时时间,`--log-level` 参数用于设置日志记录的级别。 更多的命令行参数的信息,可以在 Gunicorn 文档中找到。 ### 回答2: 使用Gunicorn启动Flask应用的示例命令如下: ``` gunicorn -w 4 -b 0.0.0.0:8000 app:app ``` 这个命令中,`gunicorn` 是 Gunicorn 的命令行工具,`-w` 用于指定工作进程的数量,这里是4个工作进程。`-b` 用于指定绑定的IP地址和端口号,这里是绑定在0.0.0.0的8000端口上。`app:app` 表示启动的主应用文件(app.py)中的 Flask 应用。请注意,如果你的主应用文件名不是 app.py,那么需要将这个参数修改为相应的文件名。 执行这个命令后,Gunicorn 会启动 Flask 应用,并监听在指定的地址和端口。你可以根据需要在后面添加其他参数,以满足你的应用需求。启动成功后,你可以在浏览器中访问 http://localhost:8000 来查看你的 Flask 应用。 ### 回答3: 使用Gunicorn启动Flask应用的示例命令如下: 假设Flask应用的文件名为app.py,应用的主要逻辑在名为app的Flask实例中。 首先,确保已经安装了Gunicorn。可以使用以下命令安装: ```shell pip install gunicorn ``` 接下来,在终端中切换到Flask应用所在的目录,然后运行以下命令启动Flask应用: ```shell gunicorn app:app ``` 在上述命令中,第一个app表示要运行的Python模块名(即Flask应用所在的Python文件名,不包括.py扩展名);第二个app表示Flask应用的实例名。 默认情况下,Gunicorn将在本地主机的8000端口上启动Flask应用。可以通过添加`-b`选项指定要使用的IP地址和端口。例如,要在IP地址为127.0.0.1、端口为5000的位置启动Flask应用,可以运行以下命令: ```shell gunicorn -b 127.0.0.1:5000 app:app ``` 运行上述命令后,Gunicorn将启动Flask应用,并在终端显示相关日志。此时,可以通过将浏览器访问http://127.0.0.1:5000来验证Flask应用是否正常运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DexterLien

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值