django-vue-admin/backend/gunicorn_conf.py

49 lines
2.3 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# gunicorn.conf
# coding:utf-8
# 启动命令gunicorn -c gunicorn.py application.asgi:application
import multiprocessing
# 并行工作进程数, intcpu数量*2+1 推荐进程数
workers = multiprocessing.cpu_count() * 2 + 1
# 指定每个进程开启的线程数
threads = 3
# 绑定的ip与端口
bind = '0.0.0.0:8000'
# 设置守护进程,将进程交给第三方管理
daemon = 'false'
# 工作模式协程默认的是sync模式,推荐使用 gevent此处使用与uvicorn配合使用 uvicorn.workers.UvicornWorker
worker_class = 'uvicorn.workers.UvicornWorker'
# 设置最大并发量每个worker处理请求的工作线程数正整数默认为1
worker_connections = 10000
# 最大客户端并发数量默认情况下这个值为1000。此设置将影响gevent和eventlet工作模式
# 每个工作进程将在处理max_requests请求后自动重新启动该进程
max_requests = 10000
max_requests_jitter = 200
# 设置进程文件目录
pidfile = './gunicorn.pid'
# 日志级别,这个日志级别指的是错误日志的级别,而访问日志的级别无法设置
loglevel = 'info'
# 设置gunicorn访问日志格式错误日志无法设置
access_log_format = '' # worker_class 为 uvicorn.workers.UvicornWorker 时日志格式为Django的loggers
# 监听队列
backlog = 512
#进程名
proc_name = 'gunicorn_process'
# 设置超时时间120s默认为30s。按自己的需求进行设置timeout = 120
timeout = 120
# 超时重启
graceful_timeout = 300
# 在keep-alive连接上等待请求的秒数默认情况下值为2。一般设定在1~5秒之间。
keepalive = 3
# HTTP请求行的最大大小此参数用于限制HTTP请求行的允许大小默认情况下这个值为4094。
# 值是0~8190的数字。此参数可以防止任何DDOS攻击
limit_request_line = 5120
# 限制HTTP请求中请求头字段的数量。
# 此字段用于限制请求头字段的数量以防止DDOS攻击与limit-request-field-size一起使用可以提高安全性。
# 默认情况下这个值为100这个值不能超过32768
limit_request_fields = 101
# 限制HTTP请求中请求头的大小默认情况下这个值为8190。
# 值是一个整数或者0当该值为0时表示将对请求头大小不做限制
limit_request_field_size = 0
# 记录到标准输出
accesslog = '-'