开发者

python3 gunicorn配置文件的用法解读

目录
  • python3 gunicorn配置文件
    • 配置文件
    • 服务启动、重启、关闭
      • 启动
      • 重启
      • 关闭
  • 总结

    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.devze.com'gevent' 
    
    # 最大的并发请求数为  workers*2000
    worker_connections = 2000
    
    # 最大客户端并发数量,默认情况下这个值为1000。此设置将影响gevent和eventlet工作模式,当最大请求数量达到时进程会重启
    max_requests = 1000  
    
    #设置进程文件目录
    pidfile = www.devze.com'/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一起使用可以提高安全性。默认情况下,这个值为10编程客栈0,这个值不能超过http://www.devze.com32768
    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

    总结

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

    0

    上一篇:

    下一篇:

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    最新开发

    开发排行榜