• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    python3 gunicorn配置文件的用法解读

    发布者: 涵韵 | 发布时间: 2025-6-17 08:09| 查看数: 77| 评论数: 0|帖子模式

    python3 gunicorn配置文件


    配置文件
    1. import multiprocessing

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

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

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

    9. #端口 5000
    10. bind = '127.0.0.1:8200'

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

    13. #工作模式协程,使用gevent模式(协程模式),默认的是sync模式,共有sync、eventlet、gevent、tornado
    14. worker_class = 'gevent'

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

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

    19. #设置进程文件目录
    20. pidfile = '/var/run/gunicorn.pid'

    21. #进程名
    22. proc_name = 'gunicorn_process'

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

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

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

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

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

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

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

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

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

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

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

    51. # 限制HTTP请求中请求头字段的数量。此字段用于限制请求头字段的数量以防止DDOS攻击,与limit-request-field-size一起使用可以提高安全性。默认情况下,这个值为100,这个值不能超过32768
    52. limit_request_fields = 101

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

    55. # 设置gunicorn使用的python虚拟环境
    56. # pythonpath='/home/your_path/venv/bin/python3'
    57. # 环境变量
    58. # raw_env = 'APE_API_ENV=DEV'
    复制代码
    服务启动、重启、关闭


    启动


    • 配置文件启动命名
    1. gunicorn -c gunicorn.py GunicornRun:app
    复制代码

    • 查看服务
    1. pstree -ap | grep gunicorn # 以树结构的形式
    复制代码


    • 或者
      1. lsof -i:端口号
      复制代码
      查看


      1. ps -ef | grep gunicorn
      复制代码
      查看


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


    重启
    1. kill -HUP 主进程号
    复制代码
    关闭
    1. kill -9 主进程号 # 如果不能完全删除,重复删除所有的进程,也可以配置sh脚本来执行一次全部删除
    复制代码
    一次性关闭所有的gunicorn进程,建立.sh文件,内容如下:
    1. for i in `ps -ef | grep gunicorn |awk '{print $2}'`;do kill -9 $i;done
    复制代码
    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

    来源:https://www.jb51.net/python/3397133vw.htm
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表