当前位置: 首页 > article >正文

[Python3高阶编程] - Gunicorn 介绍与使用指南

Gunicorn 是什么GunicornGreenUnicorn是一个 Python WSGI HTTP 服务器用于运行 Python Web 应用。它是生产环境中最流行的 Python 应用服务器之一特点是简单、轻量、高性能。客户端 → Gunicorn处理 HTTP、管理 Worker → 你的 Python 应用Flask/Django/FastAPI 等核心功能1. Worker 管理支持多种 Worker 类型适应不同场景Worker 类型适用场景说明sync默认CPU 密集型、简单请求同步阻塞每个 worker 同时处理 1 个请求gthread一般 Web 应用多线程单 worker 内多线程处理gevent高并发 I/O 密集型基于协程极高并发能力eventlet高并发 I/O 密集型类似 gevent另一种协程实现2. 进程管理Master-Worker 架构Master 进程负责管理Worker 进程处理请求优雅重启kill -HUP不中断服务热更新代码自动重启Worker 崩溃自动拉起超时杀进程Worker 超时自动终止防止卡死3. 负载均衡Master 进程自动将请求分发到空闲 Worker。4. 可观测性访问日志、错误日志StatsD 指标集成可自定义日志格式快速上手安装pip install gunicorn # 如果用 gevent worker pip install gunicorn gevent最简启动gunicorn app:app格式gunicorn 模块名:应用对象# app.py from flask import Flask app Flask(__name__) app.route(/) def hello(): return Hello World!常用参数gunicorn app:app \ --bind 0.0.0.0:8000 \ # 监听地址和端口 --workers 4 \ # Worker 数量推荐 2×CPU核心1 --worker-class gthread \ # Worker 类型 --threads 2 \ # 每个 worker 的线程数gthread 模式 --timeout 120 \ # Worker 超时时间秒 --access-logfile - \ # 访问日志- 表示 stdout --error-logfile - \ # 错误日志 --log-level info \ # 日志级别 --daemon # 守护进程模式后台运行配置文件推荐生产环境建议用配置文件而不是命令行参数# gunicorn.conf.py # 绑定地址 bind 0.0.0.0:8000 # Worker 配置 workers 4 worker_class gthread threads 2 timeout 120 keepalive 5 # 日志 accesslog - # stdout errorlog - loglevel info access_log_format %(h)s %(l)s %(u)s %(t)s %(r)s %(s)s %(b)s %(f)s %(a)s %(D)s # 进程管理 preload_app True # 预加载应用节省内存 max_requests 1000 # Worker 处理 N 个请求后重启防内存泄漏 max_requests_jitter 50 # 加随机抖动避免所有 worker 同时重启 # 钩子函数 def on_starting(server): print(Gunicorn is starting...) def post_fork(server, worker): server.log.info(fWorker spawned (pid: {worker.pid}))启动时指定配置gunicorn app:app -c gunicorn.conf.py常见框架对接Flaskgunicorn app:appDjangogunicorn myproject.wsgi:applicationFastAPI# 需要 uvicorn worker pip install uvicorn gunicorn app:app -k uvicorn.workers.UvicornWorker运维操作# 优雅重启代码更新后不中断服务 kill -HUP master_pid # 查看 master pid cat gunicorn.pid # 启动时加 --pid gunicorn.pid # 平滑关闭 kill -TERM master_pid # 强制关闭 kill -9 master_pid生产架构建议Gunicorn 通常不直接暴露给公网前面会加 Nginx 做反向代理用户 → NginxSSL/静态文件/限流 → Gunicorn应用服务器 → Python 应用Nginx 配置示例server { listen 80; server_name example.com; location / { proxy_pass http://127.0.0.1:8000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }一句话总结Gunicorn 就是 Python Web 应用的生产车间——你负责写代码它负责管理进程、分发请求、保证服务稳定运行其他注意事项不要在 Windows 上使用Gunicorn 仅支持 Unix 系统生产环境必须配合反向代理如 Nginx用于处理静态文件和负载均衡合理设置工作进程数过多会消耗内存过少会影响性能监控内存使用长时间运行可能出现内存泄漏定期重启通过max_requests参数避免内存泄漏累积Gunicorn 是一个成熟稳定的 WSGI 服务器特别适合中小型 Python Web 应用的生产部署。配合合适的配置和监控能够提供可靠的 HTTP 服务。

相关文章:

[Python3高阶编程] - Gunicorn 介绍与使用指南

Gunicorn 是什么Gunicorn(Green Unicorn)是一个 Python WSGI HTTP 服务器,用于运行 Python Web 应用。它是生产环境中最流行的 Python 应用服务器之一,特点是简单、轻量、高性能。客户端 → Gunicorn(处理 HTTP、管理 …...

重构魔兽争霸III地图编辑:HiveWE的技术革新与性能突破

重构魔兽争霸III地图编辑:HiveWE的技术革新与性能突破 【免费下载链接】HiveWE A Warcraft III world editor. 项目地址: https://gitcode.com/gh_mirrors/hi/HiveWE 行业痛点:传统地图编辑器的技术瓶颈 魔兽争霸III地图创作者长期受限于原版编辑…...

利用快马平台快速原型:五分钟构建你的第一个multisim风格电路仿真器

最近在尝试电路设计时,发现从构思到实际验证往往需要花费大量时间搭建仿真环境。传统方式需要安装专业软件、配置参数,整个过程相当繁琐。直到尝试了InsCode(快马)平台,发现它特别适合用来做电路设计的快速原型验证。下面分享如何用五分钟构建…...

LiuJuan Z-Image Generator完整指南:宽松加载strict=False适配非标权重

LiuJuan Z-Image Generator完整指南:宽松加载strictFalse适配非标权重 1. 引言:当定制权重遇上标准模型 你有没有遇到过这种情况?好不容易找到一个效果惊艳的定制版模型权重,兴冲冲地下载下来,结果在加载时却报了一堆…...

PINCache与App Extension:在扩展中安全使用缓存的完整方案

PINCache与App Extension:在扩展中安全使用缓存的完整方案 【免费下载链接】PINCache Fast, non-deadlocking parallel object cache for iOS, tvOS and OS X 项目地址: https://gitcode.com/gh_mirrors/pi/PINCache PINCache作为一款为iOS、tvOS和OS X打造的…...

TI C2000系列PGA避坑指南:滤波电阻选择与开尔文接地的5个关键细节

TI C2000系列PGA避坑指南:滤波电阻选择与开尔文接地的5个关键细节 在精密信号调理电路中,可编程增益放大器(PGA)的硬件设计往往成为系统性能的瓶颈。许多工程师在完成原理图设计后,常会遇到信号完整性不佳、底噪偏高或增益误差超标等问题。本…...

Fast-Check高级技巧:如何构建自定义Arbitrary生成器的完整指南

Fast-Check高级技巧:如何构建自定义Arbitrary生成器的完整指南 【免费下载链接】fast-check Property based testing framework for JavaScript (like QuickCheck) written in TypeScript 项目地址: https://gitcode.com/gh_mirrors/fa/fast-check Fast-Chec…...

BigDL-2.x与Spark MLlib集成:传统机器学习与深度学习的完美融合

BigDL-2.x与Spark MLlib集成:传统机器学习与深度学习的完美融合 【免费下载链接】BigDL-2.x BigDL: Distributed TensorFlow, Keras and PyTorch on Apache Spark/Flink & Ray 项目地址: https://gitcode.com/gh_mirrors/bi/BigDL-2.x BigDL-2.x是一个强…...

GeoAI实战:如何用Python和QGIS打造智能交通预测系统(附代码)

GeoAI实战:如何用Python和QGIS打造智能交通预测系统(附代码) 最近在帮某省会城市优化公交调度系统时,发现传统GIS工具处理实时交通数据就像用算盘计算火箭轨道——理论可行但实操吃力。这促使我探索出一套结合QGIS可视化优势与Pyt…...

告别鼠标手!用Python的keyboard库打造你的专属游戏/办公热键助手(附完整源码)

告别鼠标手!用Python的keyboard库打造你的专属游戏/办公热键助手(附完整源码) 长时间盯着电脑屏幕,手腕因为频繁点击鼠标而酸痛不已?这种"鼠标手"的困扰几乎成了现代办公族和游戏玩家的标配。但你可能没意识…...

Webpack开发者必备的25个工具:Awesome-Webpack终极工具集合指南 [特殊字符]

Webpack开发者必备的25个工具:Awesome-Webpack终极工具集合指南 🚀 【免费下载链接】awesome-webpack A curated list of awesome Webpack resources, libraries and tools 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-webpack 作为现代…...

终极iOS图片视频选择器HXPhotoPicker完整使用指南

终极iOS图片视频选择器HXPhotoPicker完整使用指南 【免费下载链接】HXPhotoPicker 图片/视频选择器 - 支持LivePhoto、GIF图片选择、3DTouch预览、在线下载iCloud上的资源、编辑图片/视频、浏览网络图片 功能 Imitation wx photo/image picker - support for LivePhoto, GIF im…...

Flash内容还能复活吗?这款浏览器让你重温经典Flash游戏和课件

Flash内容还能复活吗?这款浏览器让你重温经典Flash游戏和课件 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 还记得那些陪伴我们成长的Flash小游戏和交互课件吗?当…...

SQLMesh表对比功能:如何在开发和生产环境间进行数据差异分析

SQLMesh表对比功能:如何在开发和生产环境间进行数据差异分析 【免费下载链接】sqlmesh Scalable and efficient data transformation framework - backwards compatible with dbt. 项目地址: https://gitcode.com/gh_mirrors/sq/sqlmesh SQLMesh的表对比功能…...

Qwen3.5-9B-AWQ-4bit开源模型价值解析:为何选择AWQ-4bit而非GGUF或GPTQ

Qwen3.5-9B-AWQ-4bit开源模型价值解析:为何选择AWQ-4bit而非GGUF或GPTQ 1. 模型核心能力解析 1.1 多模态理解能力 Qwen3.5-9B-AWQ-4bit是一个支持图像与文本联合理解的多模态模型,其核心能力体现在: 视觉-语言联合处理:能够同…...

video-object-removal错误排查手册:常见问题与解决方法汇总

video-object-removal错误排查手册:常见问题与解决方法汇总 【免费下载链接】video-object-removal Just draw a bounding box and you can remove the object you want to remove. 项目地址: https://gitcode.com/gh_mirrors/vi/video-object-removal video…...

SQLMesh社区贡献指南:如何参与开源项目开发

SQLMesh社区贡献指南:如何参与开源项目开发 【免费下载链接】sqlmesh Scalable and efficient data transformation framework - backwards compatible with dbt. 项目地址: https://gitcode.com/gh_mirrors/sq/sqlmesh SQLMesh是一个可扩展且高效的数据转换…...

如何使用unbuild在5分钟内搭建现代化JavaScript项目:终极快速指南

如何使用unbuild在5分钟内搭建现代化JavaScript项目:终极快速指南 【免费下载链接】unbuild 📦 A unified JavaScript build system 项目地址: https://gitcode.com/gh_mirrors/un/unbuild 在当今快速发展的JavaScript生态系统中,构建…...

SVG-Morpheus实战教程:10个实用技巧打造惊艳UI动画

SVG-Morpheus实战教程:10个实用技巧打造惊艳UI动画 【免费下载链接】SVG-Morpheus JavaScript library enabling SVG icons to morph from one to the other. It implements Material Designs Delightful Details transitions. (THIS PROJECT IS NOT MAINTAINED ANY…...

[具身智能-244]:OpenCV目标跟踪应用程序调用OpenCV库函数实现该功能的主要流程

OpenCV 目标跟踪应用程序的实现流程,本质上是“初始化(定义目标) -> 循环更新(预测位置) -> 可视化(反馈结果)”的过程。这一流程完美体现了之前提到的“逻辑推演模式”:程序员…...

OpenClaw语音控制之GoogleAPI 集成实战教程

11.1 Google Cloud 账号设置 在使用 Google Cloud 的任何服务之前,首先需要拥有一个 Google Cloud 账号。本节将详细介绍账号注册、项目创建和支付方式绑定的完整流程。 步骤 1:访问 Google Cloud 控制台 打开浏览器,访问 Google Cloud 控制台地址:https://console.clou…...

如何快速创建专业作品集:awesome-portfolio-websites完全指南

如何快速创建专业作品集:awesome-portfolio-websites完全指南 【免费下载链接】awesome-portfolio-websites A community maintained open source project aimed at making a personal portfolio for researchers, developers, and analysts simple, fast, and less…...

异步编程中的重试策略:backoff与asyncio完美结合

异步编程中的重试策略:backoff与asyncio完美结合 【免费下载链接】backoff Python library providing function decorators for configurable backoff and retry 项目地址: https://gitcode.com/gh_mirrors/bac/backoff 在现代Python异步编程中,处…...

cryptocurrency-icons 的4种样式详解:从黑白到彩色全解析

cryptocurrency-icons 的4种样式详解:从黑白到彩色全解析 【免费下载链接】cryptocurrency-icons A set of icons for all the main cryptocurrencies and altcoins, in a range of styles and sizes. 项目地址: https://gitcode.com/gh_mirrors/cr/cryptocurrenc…...

Hikyuu性能优化技巧:从AMD 7950x实测看量化平台的极致速度

Hikyuu性能优化技巧:从AMD 7950x实测看量化平台的极致速度 【免费下载链接】hikyuu Hikyuu Quant Framework 基于C/Python的极速开源量化交易研究框架,同时可基于策略部件进行资产重用,快速累积策略资产。 项目地址: https://gitcode.com/g…...

pymoo实战教程:从零开始构建你的第一个多目标优化模型

pymoo实战教程:从零开始构建你的第一个多目标优化模型 【免费下载链接】pymoo NSGA2, NSGA3, R-NSGA3, MOEAD, Genetic Algorithms (GA), Differential Evolution (DE), CMAES, PSO 项目地址: https://gitcode.com/gh_mirrors/py/pymoo pymoo是一个强大的Pyt…...

FastAPI实战:为你的AI模型训练任务加一个实时日志面板(附完整前端代码)

FastAPI实战:构建AI模型训练的实时可视化监控系统 在深度学习模型训练过程中,算法工程师经常面临一个共同挑战:如何在不中断训练进程的情况下,实时掌握模型的关键指标变化。传统的SSH登录服务器查看日志文件的方式,不仅…...

Pixel Language Portal部署案例:在信创环境(麒麟OS+海光CPU)中运行Hunyuan-MT-7B

Pixel Language Portal部署案例:在信创环境(麒麟OS海光CPU)中运行Hunyuan-MT-7B 1. 项目背景与价值 **像素语言跨维传送门(Pixel Language Portal)**是基于腾讯Hunyuan-MT-7B大模型构建的创新翻译工具,其独特的16-bit像素冒险界…...

DSP数字电源方案:C2000系列主控TMS32F28069 Buck-Boost双向变换器(...

DSP数字电源方案 Buck-Boost双向变换器 数字控制方式:C2000系列 主控TMS32F28069 300W,8A,输入10-75V,输出5-75V 双向升降压功率转换器buck-boost结构 提供主板PCB,原理图(AD格式),源代码,无控制板资料。 …...

N_m3u8DL-RE终极指南:跨平台流媒体下载与加密视频处理完全解决方案

N_m3u8DL-RE终极指南:跨平台流媒体下载与加密视频处理完全解决方案 【免费下载链接】N_m3u8DL-RE Cross-Platform, modern and powerful stream downloader for MPD/M3U8/ISM. English/简体中文/繁體中文. 项目地址: https://gitcode.com/GitHub_Trending/nm3/N_…...