Flask并发

本文介绍了如何使用 Gunicorn 和 gevent 实现 Flask 应用的高并发处理,包括针对不同任务类型选择合适的 worker 模式,如 I/O 密集型、CPU 密集型和内存占用大的任务。Gunicorn 作为高性能的 WSGI 服务器,解决了 Flask 内置服务器在生产环境中的性能问题,通过预fork worker模式管理和调整 worker 进程,支持多种类型的 worker,如 Sync、Async、Tornado 和 AsyncIO,以适应不同场景的需求。
摘要由CSDN通过智能技术生成

实现 Flask 应用的高并发

Gunicorn + Flask App

安装 Gunicorn 和 gevent:

pip install gunicorn
pip install gevent

对 I/O 密集型的任务,采用 workers + gevent 的方式:

gunicorn --chdir=/home/xx/project/ run_server:app -w 9 -b
0.0.0.0:8888 -k gevent

对 CPU 密集型的任务,采用 workers:

gunicorn run_server:app -w 9 -b 0.0.0.0:8888

对于 内存占用较大的任务,采用 threads:

gunicorn run_server:app -w 3 --threads 3 -b 0.0.0.0:8888

其中,run_server 是 flask_app 的启动脚本的名字,也就是包含 app.run() 的脚本名,run_server.py app 是 Flask App 的名字。-w 代表 worker 的数量,建议是 2CPU 核数 +1,如果同时使用 workers 和 threads,建议两者数量相乘等于 2CPU 核数 +1。

查看 CPU 核数:

cat /proc/cpuinfo | grep ‘core id’ | wc -l

或者在 Python 中:

>>> import multiprocessing
>>> multiprocessing
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值