python3 gunicorn配置文件的用法解读

2025-04-16 16:50

本文主要是介绍python3 gunicorn配置文件的用法解读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《python3gunicorn配置文件的用法解读》:本文主要介绍python3gunicorn配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教...

python3 gunicorn配置文件

配置文件

import multiprocessing

#并行工作进程数
workers = multiprocessing.cpu_count() * 2 + 1
# workers = 4

#指定每个工作者的线程数,当使用gevent时,这个不起作用
threads = 4

# 控制是否在主进程中预加载应用程序。当设置为 True 时,Gunicorn 在主进程中加载应用程序,然后将其复制到每个工作进程中。当设置为 False 时,应用程序在每个工作进程中独立加载
preload_app = False

#端口 5000
bind = '127.0.0.1:8200'

#设置守护进程,将进程交给supervisor管理
daemon = 'true'

#工作模式协程,使用gevent模式(协程模式),默认的是sync模式,共有sync、eventlet、gevent、tornado
worker_class = http://www.chinasem.cn'gevent' 

# 最大的并发请求数为  workers*2000
worker_connections = 2000

# 最大客户端并发数量,默认情况下这个值为1000。此设置将影响gevent和eventlet工作模式,当最大请求数量达到时进程会重启
max_requests = 1000  

#设置进程文件目录
pidfile = www.chinasem.cn'/var/run/gunicorn.pid'

#进程名
proc_name = 'gunicorn_process'

#设置访问日志和错误信息日志路径
Accesslog = "./Log/access.log"
errorlog = "./Log/error.log"
# 当想关闭日志时可以设置
# accesslog = '/dev/null'  # 禁用日志
# errorlog = '/dev/null'  # 禁用日志

# 日志级别,这个日志级别指的是错误日志的级别,而访问日志的级别无法设置,
loglevel = "error"

  #- debug: 最详细的日志级别,通常用于调试目的。
  #- info(默认值): 提供一般的信息日志,适用于大多数情况。
  #- warning: 输出警告级别的日志消息,表示可能存在潜在问题。
  #- error: 输出错误级别的日志消息,表示发生了一些错误,但 Gunicorn 可以继续运行。
  #- critical: 输出严重错误级别的日志消息,表示发生了严重问题,Gunicorn 无法继续运行。

# 设置gunicorn访问日志格式,错误日志无法设置
access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"'  

# INT:默认情况下,这个值为30,在超时(从接收到重启信号开始)之后仍然活着的工作将被强行杀死;一般使用默认
graceful_timeout = 60

# int:未决连接的最大数量,即等待服务的客户的数量。默认2048个,一般不修改;
backlog = 2048

# 超过这么多秒后工作将被杀掉,并重新启动。一般设定为30秒;
timeout = 300

# INT:在keep-alive连接上等待请求的秒数,默认情况下值为2。一般设定在1~5秒之间。
keepalive = 5 

# reload = True  # 默认为False。此设置用于开发,每当应用程序发生更改时,都会导致工作重新启动。

# 设置这个值为true 才会把打印信息记录到错误日志里,将stdout / stderr重定向到errorlog中的指定文件
capture_output = False 

# INT:HTTP请求头的行数的最大大小,此参数用于限制HTTP请求行的允许大小,默认情况下,这个值为4094。值是0~8190的数字
limit_request_line = 5120

# 限制HTTP请求中请求头字段的数量。此字段用于限制请求头字段的数量以防止DDOS攻击,与limit-request-field-size一起使用可以提高安全性。默认情况下,这个值为10China编程0,这个值不能超过http://www.chinasem.cn32768
limit_request_fields = 101

# 限制HTTP请求中请求头的大小,默认情况下这个值为8190。值是一个整数或者0,当该值为0时,表示将对请求头大小不做限制
limit_request_field_size = 0

# 设置gunicorn使用的python虚拟环境
# pythonpath='/home/your_path/venv/bin/python3'
# 环境变量
# raw_env = 'APE_API_ENV=DEV'

服务启动、重启、关闭

启动

  • 配置文件启动命名
gunicorn -c gunicorn.py GunicornRun:app
  • 查看服务
pstree -ap | grep gunicorn # 以树结构python的形式

python3 gunicorn配置文件的用法解读

  • 或者lsof -i:端口号查看

python3 gunicorn配置文件的用法解读

  • ps -ef | grep gunicorn查看

python3 gunicorn配置文件的用法解读

  • 或直接去配置好的进程文件中查看主进程号

python3 gunicorn配置文件的用法解读

重启

kill -HUP 主进程号

关闭

kill -9 主进程号 # 如果不能完全删除,重复删除所有的进程,也可以配置sh脚本来执行一次全部删除

一次性关闭所有的gunicorn进程,建立.sh文件,内容如下:

for i in `ps -ef | grep gunicorn |awk '{print $2}'`;do kill -9 $i;done

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程China编程(www.chinasem.cn)。

这篇关于python3 gunicorn配置文件的用法解读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154247

相关文章

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

C#中DrawCurve的用法小结

《C#中DrawCurve的用法小结》本文主要介绍了C#中DrawCurve的用法小结,通常用于绘制一条平滑的曲线通过一系列给定的点,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 如何使用 DrawCurve 方法(不带弯曲程度)2. 如何使用 DrawCurve 方法(带弯曲程度)3.使用Dr

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

C++ vector的常见用法超详细讲解

《C++vector的常见用法超详细讲解》:本文主要介绍C++vector的常见用法,包括C++中vector容器的定义、初始化方法、访问元素、常用函数及其时间复杂度,通过代码介绍的非常详细,... 目录1、vector的定义2、vector常用初始化方法1、使编程用花括号直接赋值2、使用圆括号赋值3、ve

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

pytorch之torch.flatten()和torch.nn.Flatten()的用法

《pytorch之torch.flatten()和torch.nn.Flatten()的用法》:本文主要介绍pytorch之torch.flatten()和torch.nn.Flatten()的用... 目录torch.flatten()和torch.nn.Flatten()的用法下面举例说明总结torch

Python Faker库基本用法详解

《PythonFaker库基本用法详解》Faker是一个非常强大的库,适用于生成各种类型的伪随机数据,可以帮助开发者在测试、数据生成、或其他需要随机数据的场景中提高效率,本文给大家介绍PythonF... 目录安装基本用法主要功能示例代码语言和地区生成多条假数据自定义字段小结Faker 是一个 python

前端高级CSS用法示例详解

《前端高级CSS用法示例详解》在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将深... 前端高级css用法在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S