美文网首页
Gunicorn笔记教程

Gunicorn笔记教程

作者: 我的袜子都是洞 | 来源:发表于2019-08-12 23:29 被阅读0次

    Gunicorn ?

    Gunicorn“绿色独角兽”是一个被广泛使用的高性能的Python WSGI UNIX HTTP服务器,移植自Ruby的独角兽(Unicorn )项目,使用pre-fork worker模式,具有部署使用非常简单,轻量级的资源消耗,以及高性能等特点。

    Web架构图

    安装

    系统安装

    sudo apt-get update
    sudo apt-get install gunicorn
    

    pip安装

    pip install gunicorn
    

    运行

    gunicorn [OPTIONS] 模块名:变量名
    

    参数:

    • 模块名:python文件名 或 完整的路径+python文件名;

    • 变量名:python文件中可调用的WSGI(Web Server Gateway ).

    示例文件:

    # filename:test.py
    def app(environ, start_response):
      """Simplest possible application object"""
      data = 'Hello, World!\n'
      status = '200 OK'
      response_headers = [
        ('Content-type','text/plain'),
        ('Content-Length', str(len(data)))
      ]
      start_response(status, response_headers)
      return iter([data])
    

    运行app:

    gunicorn --workers=2 test:app
    

    常见[OPTIONS]参数:

    • -c CONFIG, --config=CONFIG: 指定配置文件(py文件)
    • -b BIND, --bind=BIND: 与指定socket进行绑定.
    • -D, --daemon: 以守护进程形式来运行Gunicorn进程,其实就是将这个服务放到后台去运行。
    • -w WORKERS, --workers=WORKERS: 工作进程的数量。上边提到gunicorn是一个pre-fork worker模式,就是指gunicorn启动的时候,在主进程中会预先fork出指定数量的worker进程在处理请求时,gunicorn依靠操作系统来提供负载均衡,通常推荐的worker数量是:(2 x $num_cores) + 1
    • -k WORKERCLASS, --worker-class=WORKERCLASS: 工作进程类型. 包括 sync(默认), eventlet, gevent, or tornado, gthread, gaiohttp.
    • --backlog INT: 最大挂起的连接数.
    • --chdir: 切换到指定的工作目录.
    • --log-level LEVEL: 输出error log的颗粒度,有效的LEVEL有:debuginfowarningerrorcritical
    • --access-logfile FILE: 确认要写入Access log的文件FILE. '-' 表示输出到标准输出.
    • --error-logfile FILE, --log-file FILE: 确认要写入Error log的文件FILE. '-' 表示输出到标准错误输出.

    配置

    配置来源:

    • 框架设置
    • 配置文件(python文件)
    • 命令行

    配置文件必须是py文件,本质是将命令行参数写进py文件。

    如:

    # example.py
    bind = "127.0.0.1:8000"
    workers = 2
    

    运行gunicorn:

    gunicorn -c example.py test:app
    

    其实等同于:

    gunicorn -w 2 -b 127.0.0.1:8000 test:app
    

    也可以详细配置:

    # gunicorn.py
    import logging
    import logging.handlers
    from logging.handlers import WatchedFileHandler
    import os
    import multiprocessing
    bind = '127.0.0.1:8000'      #绑定ip和端口号
    backlog = 512                #监听队列
    chdir = '/home/test/server/bin'  #gunicorn要切换到的目的工作目录
    timeout = 30      #超时
    worker_class = 'gevent' #使用gevent模式,还可以使用sync 模式,默认的是sync模式
    
    workers = multiprocessing.cpu_count() * 2 + 1    #进程数
    threads = 2 #指定每个进程开启的线程数
    loglevel = 'info' #日志级别,这个日志级别指的是错误日志的级别,而访问日志的级别无法设置
    access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"'    #设置gunicorn访问日志格式,错误日志无法设置
    
    """
    其每个选项的含义如下:
    h          remote address
    l          '-'
    u          currently '-', may be user name in future releases
    t          date of the request
    r          status line (e.g. ``GET / HTTP/1.1``)
    s          status
    b          response length or '-'
    f          referer
    a          user agent
    T          request time in seconds
    D          request time in microseconds
    L          request time in decimal seconds
    p          process ID
    """
    accesslog = "/home/test/server/log/gunicorn_access.log"      #访问日志文件
    errorlog = "/home/test/server/log/gunicorn_error.log"        #错误日志文件
    

    相关文章

      网友评论

          本文标题:Gunicorn笔记教程

          本文链接:https://www.haomeiwen.com/subject/ckkmjctx.html